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PREFACE 


This User’s Manual contains the information you will need to use your PROMPT 48. 
The information presented herein is adequate to support normal user needs. Additional 
information is available in the following documents. 

MCS -48 Microcomputer Use f s Manual, Order No. 9800270 
MSC-48 Assembly Language Manual, Order No. 9800255 
PROMPT 48 Reference Car diet. Order No. 9800404 
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CHAPTER 1 
INTRODUCTION 


1-1. How To Use This Book 


The cost of computers is now low enough that your software design and debug time is likely 
to be a critical consideration. No doubt your decision to use good tools like Prompt 48 was 
based on this kind of logical thinking. Since your time is valuable, this book is organized as 
a reference work, not as a mystery story. Every page has headings that identify the topics on 
that page. Look up what you want to know, in whatever order you need the information. If 
Prompt 48 is new to you, you probably will want to go through the familiarization exercise 
in Appendix A. Before operating Prompt 48 for the first time, please check the caution items 
that follow. 


1-2, Voltage Selection 

Is the voltage selection switch on the back of Prompt 48 set for your local mains (line) 
voltage? If not, open the Prompt box, remove the switch locking plate, and set the switch 
properly, then reassemble the unit. If you change the switch setting, the fuse likely must be 
changed to correspond. Ratings are: 

105-125 V - 2 A 
208-250 V - 1 A 

Now you may plug Prompt 48 in and turn it on. 


1-3. Handling The Processor 

THE CHIP COMPUTER IS FRAGILE! Dropping, twisting, or uneven pressure may break 
it. Leave it in its protective package until ready to use it. Never press down upon the quartz 
window area of the processor, or exert twisting or bending forces on any device. Never 
subject any MOS device to the discharge of static electricity; touch the chassis of Prompt 48 
before inserting a device in the socket on its panel. 


1-4. Inserting Processor In Execution Socket 



Never insert a processor in the PROGRAMMING SOCKET unless a second 
processor is properly locked in the EXECUTION SOCKET. 

Release the locking lever. Gently seat the processor in the Execution Socket, 
notched end away from you. Move the locking lever down flush with the panel. 
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1-5. The Purpose of Prompt 48 

The difference between a computer and other calculating or controlling devices is the 
general-purpose nature of their programmability. The 8048 is a true general-purpose digital 
computer. Its purpose is undetermined until you design software for it, commit that software 
design to a mask, and maunfacture the chip. 

Prompt 48 is a tool to aid you in learning MCS-48 programming and in writing, debugging, 
and testing the programs you write. There is enough information here to get you started, 
whether or not you have ever written a program before. 

Prompt 48 is a machine -language computer; making it support assembly -language pro- 
gramming would have considerably raised its cost. Even so, it is general purpose, and 
can be used to perform a variety of tasks, among which are the control of TTL- 
compatible devices and the programming of PROMs. It can function as an Intellec 
Microcomputer Development System peripheral in the latter respect. Once a program 
has been deposited in an 8748 computer, that device can be installed in the 
EXECUTION SOCKET on the panel of Prompt 48. The pins of either executory 
processor — 8748 or 8035 — can be directly interfaced to your prototype via the I/O 
PORTS AND BUS CONNECTOR and a cable set provided with Prompt. 

All of Prompt 48 ’s circuitry is located on a single board just beneath the panel. Aside from 
the power supply, the remainder of the Prompt 48 ’s cabinet is empty. A slot at the back of 
the cabinet provides access for interconnections. 

1-6. Getting Started 

Entering a program into Prompt 48’ s random-access memory (RAM) is easy. The example 
that follows can be loaded and run without any more instructions than are given here in this 
paragraph. (The MCS-48 Assembly Language Manual has some other sample programs of 
a tutorial nature.) Do the following, step by step, and you will be running a program in a 
matter of minutes. 

a. Connect power to Prompt 48. 

b. Install the 8035 computer in the EXECUTION SOCKET. (Observe the precautions in 
paragraph 1-3.) 

c. Turn power ON. The display should respond with ACCESS = 0. If not, press 
[SYS RST] . 

d. Enter the program by pressing each COMMANDS or HEX DATA/FUNCTIONS 
key in the order listed on the next page. Each [ ] represents one keystroke. At the end 
of each step (which may be several keystrokes), the results shown in the column at 
right should appear on the display. If you make a mistake and the wrong data appears, 
you can correct it by keying the field over again before touching the NEXT [,] key. If 
you realize a mistake after incrementing to the next address, you can go back and cor- 
rect it by pressing the [ ] CLEAR ENTRY/PREVIOUS key and then keying the 
step over again. 


Step 

Action 

Function 

Result 

Address 

Data 

Instruction 

Mnemonic 

Comment 

1. 

[ ] EXAMINE/MODIFY 

E 




SELECT FUNCTION 


[ ] PROGRAM MEMORY 

EP 




SELECT PROGRAM MEMORY 


[0] 

EP 

0 



ADDRESS 0 

2. 

[.] [1] [7] 

EP 

0 

17 

INCA ; 

INCREMENT ACCUMULATOR 

3. 

[.] [0] [4] 

EP 

1 

04 

JMP 

JUMP TO LOCATION 


[.] [0] 

EP 

2 

00 


00 
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CHAPTER 2 

THE NUMBER SYSTEM AND ITS SYMBOLS 


2-1 . Why Computers Need Symbols 

Digital computers perform functions accurately and at high speed by manipulating symbols 
(characters) according to a set of instructions. Computer operation consists of the execution 
of sequences of symbolically coded instructions and data. Within the machine, both data 
and instructions are usually described in binary -number codes. 


To understand the computer, you will need to understand how numbers are represented. Our 
starting point is the study of the simplest of numbering systems — the binary number system. 
But first, some definitions. 


2-2. Number Systems 

A number system is a set of symbols that may be operated upon by arithmetic rules. The 
individual symbols are called digits, and each digit is assigned its own name. The decimal 
system, as the name suggests, has ten digits: 0, 1, 2, 3, 4, 5, 6, 7, 8, 9. A number system 
also has a set of rules that define how to arrange the digits to form numbers. A number is, 
therefore, a sequence of digits interpreted according to a particular set of rules. 


Positional notation allows numbers to be written that express all quantities, no matter how 
large or how small. The real value of a digit depends on its position in the number. The digits 
of the number 5555 are identical, yet each has a different value. To write 5555 is a compact 
way of writing five thousand + five hundred + fifty -f- five or, expressed in powers of 10, 
5 X 10^ + 5 X 10^ + 5 X 10^ + 5 X 10^. The number 10 is the base, or radix, of the 
decimal system. After learning a few simple rules (and memorizing or referring to some 
unfamiliar addition and multiplication tables), it is easy to perform calculations in any 
non-decimal system. This chapter is concerned with the binary number system, whose radix 
is 2, and the hexadecimal system, whose radix is 16. 


2-3. Binary Numbers 

Binary numbers are written using radix 2. That is, each column represents a power of 2, just 
as in decimal, each column represents a power of 10. The binary number 101101 can be 
written IOIIOI 2 . Its value is expressed in the equation: 

101 IOI2 =1X2® + 0X2^+1X2^ + 1X22 + 0X2^ + 1X2 
= 1x32 + 0x16+1x8+1x4 + 0x2+1x1 
= 45io 
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The following table lists eleven binary numbers and their decimal equivalents. 


Binary 

Decimal 

2^ 2^ 2^ 2^ 2^ 


0 0 0 0 0 

0 

0 0 0 0 1 

1 

0 0 0 1 0 

2 

0 0 0 1 1 

3 

0 0 10 0 

4 

0 0 10 1 

5 

0 0 110 

6 

0 0 111 

7 

0 10 0 0 

8 

0 10 0 1 

9 

0 10 10 

10 


Computer people have become accustomed to referring to digits in the binary system as bits, 
which is a contraction of binary digits. 


2-4. Converting Decimal Numbers to Binary Numbers 

A simple method, suitable for converting large numbers, consists of repeatedly dividing the 
decimal number by 2. The remainder at any step of the division can only be 0 or 1 . These 
remainders are the bits of binary equivalent. To illustrate, convert 37 lo to its binary 
equivalent. 



37 

18 remainder 1 = 2^ (least significant digit) 
9 remainder 0 = 2^ 

4 remainder 1 = 2^ 

2 remainder 0 = 2^ 

1 remainder 0 = 2^ 

0 remainder 1=2^ 


Binary equivalent = 


2-5. Converting Binary Numbers to Decimal Numbers 

The obvious method for binary to decimal conversion is to select the one bits in the binary 
number and convert each one to decimal and then add the results together. 

2 ^ 2 ^ 2 ^ 2 ^ 2 ^ 2 ® 

37io =10 0 10 1 

= 1 X 2^ + 1 X 2^ + 1 X 2^ 

= 32 4- 4 +1 

= 37io 


2-6. Binary Arithmetic 

Binary arithmetic operations are much simpler to perform than decimal number system 
operations. So much simpler that the advantage of using fewer digits to express a given 
value in the higher radix is more than offset. The rules of arithmetic are identical in both 
systems. 


Prompt 48 
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2-7. Binary Addition 

All of the possible combinations that can occur when two bits are added are shown in the 
following addition table: 


0 

0 

1 

1 

+0 

+1 

+0 

+1 

0 

1 

1 

0 with a carry of 1 


A carry 1 bit is produced from the addition of 1 and 1 . Binary carries are treated in the same 
way as decimal carries; they are carried over to the left. In decimal, 1 + 1 = 2io, but since 
1 is the largest bit, 2 must be written as IO 2 . Example: 


Decimal 

15 

+ 7 

22 


Binary 

nil 
+ 111 

10110 


2-8. Binary Subtraction 

As in the binary addition table the binary subtraction table contains only four entries: 


0 

1 

1 

0 

-0 

-0 

-1 

-1 

0 

0 

0 

1 with a borrow of 1 


A borrow must be made in order to subtract a larger bit from a smaller bit, just as in a 
decimal subtraction. Since there are only two bits, this only happens when 1 is subtracted 
from 0. In this case a 1 is borrowed from the next column to the left. All binary subtraction is 
performed according to the subtraction table. Example: 


Decimal 


Binary 

15 

minuend 

nil 

- 7 

subtrahend 

- Ill 

8 


1000 

Decimal 


Binary 

15 


1111 

- 6 


- 110 


1001 


The arithmetic used in most computers performs subtraction in a different way than we are 
accustomed to using for decimal arithmetic. The method used is called the complement 
method. Its advantage lies in simpler physical circuitry to obtain the same result. 
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Here is how the complement method would work in the familiar decimal system. First, form 
the ten’s complement (in binary we would form the two’s complement). To form the ten’s 
complement, subtract each digit from 9, forming the nine’s complement, and then add one 
to the number as a whole: thus the ten’s complement of 0123456789io is 

9999999999 

-0123456789 

9876543210 nine’s complement 


9876543211 ten’s complement 

Then, subtracting a subtrahend from a minuend is simply adding the minuend complement. 

Example: Subtract 56io from 231io 

NORMAL COMPLEMENT 

231 minuend 231 

—056 subtrahend +944 (ten’s complement) 

175 (1)175 

Notice that the carry digit is ignored in the complement method. The subtrahend is the 
smaller of the two numbers. If not, invert the problem and change the sign of the result. 

So the rule for ten’s complement subtraction is 

Add the ten’s complement of the subtrahend to the minuend, ignoring the carry digit. 

You can see that in the decimal system the ten’s complement system is cumbersome. 

The binary number system used by computers, however, makes subtraction by comple- 
menting simple, first, form the two’s complement. Subtract each digit from 1 , forming the 
one’s complement, and then add one to the number as a whole: 

11111111 

-00000101 

11111010 (I’s complement) 

+ 1 

11111011 (2’s complement) 

Then, subtracting a subtrahend from a minuend is simply adding the minuend complement: 
00001010 

+ 11111011 (2’s complement) 

00000101 

As before, the carry bit is ignored. 

In fact, subtraction in the MCS-48 family of computers is explicitly programmed by the 
complement method. Suppose you wanted to subtract A from RO, leaving the answer in A. 
You would program 

CPL A ;forms I’s complement of A. 

INC A ;now 2’s complement of A. 

ADD A,R0 ; A now contains the desired subtracted result. 

There need not be a subtract (SUB) instruction. 
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2-9, Binary Multiplication 

There are two simple, easy-to-remember rules for binary multiplication: 


1 . The product of 1 x 1 = 1 

2. All other products = 0. 

0 10 1 

xO xO x1 x1 

0 0 0 1 


The reason for the simplicity of binary multiplication is readily apparent. Any number, digit 
or bit multiplied by 0 produces a product of 0. The simple procedure of binary multiplication 
is illustrated in the following example: 


Decimal 

7 

X 5 
35 


Binary 

111 multiplicand 
xlOl multiplier 

111 

000 partial products 
111 

100011 product 


Binary multiplication involves a series of shifts and additions of the partial products. The 
partial products are easily found since they are equal to the multiplicand or to 0. Every 1 bit 
in the multiplier gives a partial product equal to the multiplicand shifted left the correspond- 
ing number of places . Every 0 in the multiplier produces a partial product of 0. Each partial 
product is shifted left one position from the preceding partial product, the Same as in 
decimal arithmetic. 


It is useful to remember that shift operations are used to multiply or divide binary numbers 
by powers of 2 (not multiples of 2) . A left shift of one position multiplies by 2; a left shift of 
two bit positions multiplies by 4. Similarly, a right shift of one position divides by two (i.e. , 
multiplies by 1/2); a right shift of two positions divides by four. 


2-10. Binary Division 

Binary division is performed in much the same way as decimal long division. The process is 
much simpler, since there are only two rules in binary division. 


0 

1 

— = 0 

— = 1 

1 

1 
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Division by 0 (1 -r 0, 0 0) is meaningless in any numbering system. The following 

examples illustrate the binary division process: 


Decimal 

3 

3jV 

9 


1 

4 JlS 
28 


Binary 

n 

11 ) 1001 
11 


on 

11 


111 

100 hiioo 

100 

no 

100 

100 

100 


Decimal 


Binary 


12 

11 ) 132 
11 


1100 

1011 ) 10000100 
1011 


22 1011 
22 1011 


So, a computer does division in the reverse way as multiplication, by a series of subtractions 
and right shifts to provide partial dividends as opposed to a series of additions and left shifts 
to provide partial products. 


2-11. Hexadecimal Numbers 


The principal drawback of binary notation is the relative length of the numbers. It is tedious 
to write, and so more vulnerable to error. 


One shorthand method of expressing any group of four bits is the hexadecimal number 
system. This is not a code, merely a means of replacing four consecutive bits by a single 
character. Since any four bits may represent the numbers 0 through 15, then 16 single -digit 
numbers are required to replace the 16 binary numbers. For convenience, hexadecimal 
numbers are symbolically represented by a set of familiar characters, arranged in a familiar 
order. 
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Binary 

Decimal 

Hexadecimal 

0000 

0 

0 

0001 

1 

1 

0010 

2 

2 

0011 

3 

3 

0100 

4 

4 

0101 

5 

5 

0110 

6 

6 

0111 

7 

7 

1000 

8 

8 

1001 

9 

9 

1010 

10 

A 

1011 

11 

B 

1100 

12 

C 

1101 

13 

D 

1110 

14 

E 

1111 

15 

F 


Since data is often represented by binary numbers in some codes, hexadecimal notation can 
be used to express data. Prompt 48 uses 8-bit bytes, which can be expressed in two 
hexadecimal characters. The computer still reads only binary numbers; hexadecimal is the 
user’s shorthand, not the computer’s. The smallest hexadecimal number is OOie 
(OOOOOOOO 2 ) and the largest is FFie (IIIIIIII 2 ). 


When making translations, you may find it helpful to divide each 8-bit byte into two 4-bit 
nibbles. The left nibble represents the left (most significant) hexadecimal digit, and the right 
nibble represents the right (least significant) hex digit. For example. 011 1001 12 (115io) 
might for convenience be written: 


0111 0011 
7 3 


i.e., 73ie, which looks a lot like 73io but is larger in value. 


For another example, 1 101 101 12 , which translates into decimal as 219io, can be translated 
into “hex” like this: 


1101 1011 
D B 

If thinking of DBie as a number somewhat larger than the number of bones in your body is 
hard, you can calculate it using an equation much like the one used to find the decimal value 
of binary numbers, thusly: 


DB 16 = 13 X 16^ + 11 X 16® 
= 13 X 16 + 11 X 1 
= 208 + 11 
= 219io 


the decimal value stated previously. In hex, there are only two digits to contend with, and 
each of those could be looked up in a table and thereby translated from binary in one step . As 
you can see, there is no direct way to divide a binary number into decimal nibbles. That’s 
why Prompt 48 uses a hexadecimal display and keyboard. 
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Since hexadecimal notation is merely a shorthand for binary notation, hexadecimal 
arithmetic — addition, subtraction, multiplication, and division — is simply binary arithme- 
tic. Thus, 


Binary 

Decimal 

Hexadecimal 

1001 

11 

B 

+1010 

+ 10 

+ A 

1001 I 2 

2 I 10 

1^16 

1011 

11 

B 

-1010 

-10 

-A 

1 

1 

1 


Prompt 48 has a built-in hexadecimal calculator which facilitates hex addition and 
subtraction. 

Throughout this book, numerical values are stated in decimal numbers without subscript, 
and program addresses and steps are stated in hexadecimal numbers without subscript. 
Some books use suffix H to indicate hex, D for decimal, and B for binary. 


2-12. Electrical Representation of Binary Digits 

So far, the bit has been discussed in terms of 1 or 0. This is fine for arithmetic and logic 
representation using a pencil and paper, but a computer is an electronic device, and needs 
two signal states' that: 

a. Can be represented by high speed circuits. 

b. Can be readily distinguished. 

c. Cannot be confused. 

In general, computers use voltage levels to represent binary digits. The level may be present 
for a relatively short time period (or pulse) or a longer time period (which still may be a pulse 
or a level). 


2-13. Positive True Logic 

One representation of a logic level is termed positive true, and the companion voltage levels 
are +5 Vdc and OVdc, such that: 


+ 5V = 1 = HIGH = TRUE 
OV = 0 = LOW = FALSE 


If the output of a logic element (circuit) is + 5 V, that output may be referred to as logic 1 , or 
high, or true, depending upon the function of the logic element, i.e., whether it represents 
data in some form, or a timing or control function. Conversely, when the output is 0 V it may. 
be referred to as a logic 0, or low, or false. 
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2-14. The Inverse State (Negative True) 

Certain logic elements have two outputs, the one being the inverse of the other in terms of 
voltage levels. In certain cases a level is purposely inverted because it is easier to use its 
inverse. What does this mean? 


Consider a logic element that has two outputs, which are named for schematic or illustrative 
purposes. Now suppose that the logic element performs a control function and that the 
control function is termed Fetch. The mnemonic for one output could be FETCH, and by 
adopting the bar convention the other output would be FETCH/. How then is the Fetch 
control function expressed in these terms? 


FETCH =5V=HIGH = 
FETCH/ = OV = LOW = 


FETCH = OV = LOW = 
FETCH/ = 5V = HIGH = 


TRUE 

The Fetch control 

TRUE 

is applied 

FALSE 

The Fetch control 

FALSE 

is not applied 


Since the two signals are derived from the same logic element, they will always be opposite, 
the one being the inverse of the other. However, you cannot say that if FETCH = TRUE, 
then FETCH/ = FALSE. Both levels must be either true or false at the same time. The 
foregoing applies to any signal or bit that has dual representation. 
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CHAPTER 3 
HOW THE INTEL MCS-48 
CHIP-COMPUTERS WORK 


3-1. Historical Perspective 

The Intel MCS-48 Chip- Computers are truly computers-on-a-chip, unlike earlier “micro- 
processors.’ ’ Within this single-chip microcomputer are included all the computer building 
blocks which have traditionally come to be regarded as basic: Central Processing Unit, 
Memory, and Input/Output. 

The concepts leading to present-day computers date back as far as the 1830’ s, when Charles 
Babbage envisioned his “Analytical Engine.’’ Babbage’s design included all the major 
components of a general-purpose digital computer. He foresaw that its “store’’ (memory) 
should hold a thousand 50-digit numbers. Its “mill’’ (processor) would perform operations 
on the information and return the results to the “store.’’ Babbage’s concept was complete 
and accurate, for as in modern-day computers, it included “sequence mechanisms’’ which 
would select the proper numbers from the “store’’ and instruct the “mill’’ to perform the 
proper operation. But mechanical technology (later joined by electrical) required one 
hundred years to realize a working computer according to Babbage’s conception. 

This was the relay-powered “Complex Computer’’ built by Dr. George R. Stibitz at Bell 
Laboritories around 1939. Stibitz used a roomful of reliable, proven telephone relays to 
perform a limited repertoire of arithmetic operations. It worked, and was very fast alongside 
the manual calculation methods available to mathematicians in 1939 . It was not a general- 
purpose machine. 


3-2. The Harvard Architecture 

The great technical visionary, Howard Aiken, conceived that the technique of Stibitz could 
be extended to fulfill Babbage’s dream of a practical, general-purpose computer. His 
conception was of an electronic machine with vacuum-tube memory banks, used to store 
both numerical data and changeable programs for the processing of that data. His particular 
design called for split, independent memories for “data” and “programs.” He wrote the 
specification for such an “Automatic Sequence-Controlled Calculator” in 1937. 

Seven years later, the development and manufacturing skills of IBM Corporation 
successfully completed and installed this system, Mark I, on which the Harvard 
Computation Laboratory was founded. It was 51 feet (15.5 Meters) in length. Its 
information was input by four paper-tape readers. Three were dedicated to data, one to 
programs, whose instructions were coded in the sequence “source, destination, opera- 
tion.” The Mark I was very slow by modern standards: about 1/3 second was required to 
execute a single ADD instruction. 


3-3. Princeton Heard From 

A computer named ED VAC was the result when mathematician John von Neumann and his 
colleagues at Princeton constructed a machine for the U.S. Army. EDVAC could store 4K 
of a mixture of 40-bit data words and program instructions in its vacuum-tube memory 
matrix. The principal von Neumann introduced is that of numerical coding of programs, in 
exactly the same format as data, stored side-by-side in the same memory. This was a 
technique of such power and flexibility (especially so in an era when memory was costly) 
that it has been adopted and used virtually universally. Intel’s 8008 and 8080 series of 
microprocessors are designed fundamentally around the Princeton architecture; they are 
“von Neumann” machines, employing a “monomemory” addressing scheme. On the 
other hand, the 4004 and 4040 are “Aiken’ ’ machines, featuring the Harvard Architecture, 
employing separate program and data memories. 
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3-4. The MCS-48 Architecture 


3-5. Bits, Bytes, and Where You Can Put Them 

The basic unit of information in virtually any computer system today is the bit. A bit is a 
binary (base 2 ) digit; that is, it can be either a 0 or a 1 , represented in a computer as a low or a 
high voltage level. In the MCS-48 series computer systems, bits are handled in groups of 
eight. Space for data is allocated in these eight-bit bytes . For easy identification, the bits in a 
byte are numbered according to their position, or power of 2, from 0 through 7, or least 
significant bit (LSB) to most significant bit (MSB), thus: 


L-i 1 L I II I I 

7 6 5 4 3 2 1 0 

MSB LSB 


An eight-bit byte is conventionally broken up into four-bit half bytes, called nibbles. A 
nibble, containing four bits, can represent 2 ^ = 16 different numbers, from 0000 to 1111 . 
For programming convenience, four-bit nibbles are usually represented as a single 
hexadecimal digit (base 16), from 0 to Fi 0 . To understand the inner workings of the 
computer you need to think binary, but when you are writing programs for the MCS-48 
chip-computers you’ll be writing hex numbers, rather than bits. 

A register is a place to store binary data so it can be worked with. Most MCS-48 registers are 
8 -bits wide (one byte). Each MCS-48 Chip-Computer contains Register Memoiy, Data 
Memory, and separate Program Memory, thereby reintroducing the Harvard Architecture. 
The MCS-48 also retains the Princeton concept of program instructions coded in the same 
numerical format as data. Program memory is thus also organized as 8 -bits (one byte) wide 
per location. 


3-6. Accumulator 

The first register to be explained is the accumulator, designated A. An accumulator is 
something like the display register in an electronic calculator. The accumulator is the focal 
point of a majority of the instructions the computer can execute . Most arithmetic and logical 
functions are performed on the data within the accumulator, or between the accumulator 
data and the contents of other data sources (registers and data memory). The accumulator is 
also the channel through which all data is transferred to and from external devices, and can 
be used to access data contained in program memory. 

We will illustrate the architectural features of the MCS-48 family with a device known as 
the Micromap, which will gradually increase in complexity until it becomes a quick 
reference to the features and capabilities of the MCS-48. The first Micromap, emphasizing 
the accumulator, appears below. 


3-7. Register Memory, Working Registers, and RAM Pointers 

The MCS-48 Chip-Computers contain 64 8 -bit bytes of register memory, numbered 
OO- 3 Fi 0 . These registers are divided into two major types, working registers and data stor- 
age registers. The working registers have the special capability of being directly accessible 
through a wide variety of register-accumulator instructions and register-only instructions. 

The working registers are divided into two banks of eight registers each, designated RO, R1 , 
. . . , R7 , of which only one bank is directly accessible at any given time . Working Register 
Bank 0 (RBO) is found in locations 0-7 of the register memory , and working Register Bank 1 
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(RBI) in locations ISig — IFie- The bank currently being used is selectable under software 
control (see paragraph 3-17). 

Two working registers in each bank, RO and R1 , are also called RAM Pointers. Data storage 
registers are only accessible through the use of the RAM Pointers. The RAM Pointers can 
(in addition to the general capabilities of work registers) also function as “index’ ’ registers. 
That is, they can contain the address (register number) of a byte of the register memory 
whose data is to be accessed through certain instructions. 


3-8. Program Memory and Program Counter 

Program memory, like register memory, is a place to put information; in this case, the 
instructions to be carried out by the computer. In MCS-48 computers program memory is 8 
bits (one byte) wide. In the 8048 and 8748, there are 1024 (Ik) bytes of program memory 
on-chip, addressed as locations OOO-SFFjg. 

The program memory is accessed by means of the program counter. The program counter is 
a 12-bit register containing the address of the next instruction to be executed by the 
computer. Most instructions are executed sequentially in ascending addresses of program 
memory. That is, the program counter is “incremented” after each instruction. Breaks in 
the normal sequence of program execution are achieved through ‘ ‘jump” commands, which 
load the program counter with an address other than that of the next instruction in program 
memory. Note that a 12-bit register can address 2^^ = 4096 locations. The 3072 addresses 
not on-chip are located in external program memory, discussed in Paragraph 3-12. 
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The MCS-48 Chip- Computers manage program memory in 256-byte pages. The most 
significant hex digit of the program memory address is the page number; the entire 
4096-byte address range of the MCS-48 would amount to sixteen pages. The two least 
significant hex digits point to 256 adjacent memory locations, numbered XOOie “XFFie, 
where X is the page number in hex. Memory paging is implied by the fact that only the 8 
least significant bits increment automatically after each instruction. The two exceptions to 
this rule (the only means to cross “page boundaries”) are the CALL and IMP instructions, 
which provide an additional 3 more significant bits of address information (a total of 1 1 
bits) . A 1 2^^ and most significant bit exists in the program counter, called the Memory Bank 
select, or MB bit. This bit may be manipulated by software to select either of two 2k regions 
(upper or lower) of program memory through the Designated Bank Flag (DBF), which is 
moved into MB on the execution of a CALL or IMP instruction (see Paragraph 3-17). 


3-9. Flags and Stack 

The flags in the MCS-48 are independent on-bit registers which are used as aids to various 
processing tasks . Four of the flags are organized into half of the flags register which contains 
the processor status word, or PSW. These four are the Carry (C) , Auxiliary Carry (AC) , user 
Flag 0 (FO), and working register Bank Select (BS) flags. The C flag represents the carry (or 
borrow) from the last addition (or subtraction). The AC flag represents the carry from bit 3 
to bit 4 of the last addition, which is needed for decimal arithmetic. FO is set, reset, and 
sensed by software, and is useful as a means of communicating between two parts of a 
program. BS determines which working register bank is currently in use: RBO (register 
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memory locations 0-7) or RBI (locations ISig — IFie). Contained elsewhere in the MCS-48 
are user Flag 1 (FI — used like FO), the Timer Flag (TF — see Paragraph 3-10), and the 
Designated Bank Flag (DBF — see Paragraph 3-8). 


Also stored in the flags register are the three STP bits, the stack pointer. The stack pointer is 
used to manage the MCS-48 stack. A stack is a splendid way to organize activities that 
cannot be done at the same time. Here is an example from day-to-day life. Suppose that you 
are writing at your desk and the phone rings. You set aside the writing (intending to return to 
it) to take care of the phone call. Then a second person calls. You place the first caller on 
hold and answer the second caller’s question. Then you return to the first caller and 
ultimately to your writing. 


How do you organize your responses to these multiple demands? When the first phone rings 
you remember (perhaps on a mental list of things to do, or mental “stack”) that you will 
return to the writing. And when the second call comes you decide that the first call can be put 
on hold, or stacked, for later return. 


Your first call is now the most recent item on hold (on your stack) . You will return to the first 
caller when you have disposed of the second caller and then resume writing after both calls 
are finished. Interrupted activities are pushed onto the stack to save them for later. When an 
interrupting activity is finished, the interrupted activity is popped off of the stack to restore it 
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for completion. The MCS-48 computers have facilities which allow a program to be 
interrupted, made to perform more urgent tasks, and later be returned to the original activity 
through the use of a stack. 


In the MCS-48 Computers, the stack is implemented by saving the contents of the program 
counter (return address in the interrupted activity) and the C, AC, FO, and BS bits of the 
flags register (status of the interrupted activity). The twelve bits of the program counter and 
the four bits of the flags register are combined into two bytes, which are saved on the stack. 
The stack is a special area of register memory, locations 8i6 — 17ie. These sixteen bytes of 
register memory are divided into eight two-byte stack locations, or levels. This allows eight 
levels of “nesting,” or eight interrupted activities waiting on the stack. 


STACKED CURRENT 

ACTIVITIES ACTIVITY 


1st CALL 


WRITING 


2nd CALL 
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The stack is maintained through the use of the stack pointer (STP) , the three low order bits of 
the flags register. These three bits can point to (address) the 2^ = 8 stack locations. Note that 
the STP bits do not form the actual address in register memory of the stack, but rather 
indicates the next available stack entry, called the stack ‘ ‘top. ’ ’ When STP = 000, the stack 
is on level 0, and the next available stack location is at register memory locations 8 and 9. 
Similarly, when STP = 001, the stack is on level 1, and the next location is in register 
memory and Bie. 


The format of a stack push is shown in Figure 3 - 1 . The eight low order bits, bits 7 to 0, of the 
program counter, are saved in the low order byte, the lower address of the stack registers. 
The four flag bits are combined with the program counter bits 11-8 (including MB) to form 
the upper byte of the stack entry. After the transfer, 1 is added to the stack pointer to point to 
the next available stack entry, on the next level. 


A stack pop is shown in figure 3 -2 . The stack pointer (STP) points to the next available stack 
level. First, 1 is subtracted from the stack pointer. Then the data to restore the interrupted 
activity is transferred from the now available stack location to the appropriate registers. 


The stack is also used to manage subroutines. A subroutine is a part of a program that is used 
(“called”) by other parts of the program. An example would be multiplication routine, 
which would calculate and “return” the answer, the product. As with interrupts, the status 
and return address are saved on the stack, and can be restored to the flags and program 
counter registers in order to return to the calling routine (previous activity). In most cases 
though, the status of the subroutine does not interfere with the main (calling) program 
(self-interrupted activity), so there is a special instruction to pop only the return address 
from the stack for use with subroutines (see Paragraph 3-17). 


All this is not to say that the memory in which the stack resides is any different then the data 
storage registers, for they are equally accessable through the use of the RAM pointers. 
While the register memory is available for data storage on those levels of the stack which are 
not needed to monitor multiple activities, this very availability should be carefully checked. 
Writing a byte of unrelated data over a return address can be disastrous. 


3-10. Timer/Event Counter 

Each MCS-48 computer has an on-chip timer/event counter to count external signals or to 
generate time delays without tying up the processor. Basically, it is an 8-bit register that 
(when enabled) increments every time it gets an input, and sets a flag when full. The input 
can be either an external signal, or an internally generated signal, equal to 1/480 of the clock 
crystal frequency. These are the event counter and timer modes, respectively. Dividing the 
clock frequency by 480 means that, for example, if the system clock crystal frequency was 3 
MHz, the timer would increment every .16 msec. This is equal to 32 instruction cycles. 
When the timer/event counter is full (all ones), the next increment resets the timer/event 
counter to zero, and sets the Timer Rag (TF). This flag can then be used by the software to 
decide whether it is time to perform a time- or external event- dependent action. The 
timer/event counter continues incrementing on each input, regardless of the reset when full, 
until stopped by software. The instructions used to control and monitor the timer/event 
counter are described in Paragraph 3-16 and the MCS-48 Microcomputer User's Manual. 
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3-11. Input/Output Ports 

The MCS-48 chip-computers each have 27 lines which can be used for input/output 
functions. Comprising 24 of these lines are the three on-chip input/output ports, Bus (or 
PO), PI, and P2. 


Bus is an 8-bit bidirectional port with associated input and output strobes. Ports PI and P2 
are identical, latched static ports, i.e., data written out to these ports remains until 
something else is written there. They are called quasi-bidirectional because they can be 
driven as inputs when they have been latched high as outputs. (That’s because the output 
impedance of each line is relatively high, so that a standard TTL gate can pull it down.) This 
quasi-bidirectional operation is described fully in the MCS-48 Microcomputer User’ s 
Manual. 

Of the remaining three lines, TO and T1 serve as external signal inputs, and are testable with 
conditional jump instructions. INT/ is an input which initiates an interrupt if enabled by 
software. The relevant instructions are given in MCS-48 Assembly Language Manual, 
and the hardware operation is described in detail in the MCS-48 Microcomputer User’s 
Manual. 
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3-12. External Memory and Ports 

In addition to the on-chip features of the MCS-48 computers, there are several expansion 
features which require additional hardware beyond the single-chip computer. These are 
external program memory, external data memory, and external I/O ports. 


3-13. External Program Memory. If a given application requires more than the 1024 
program memory bytes included on-chip, there is provision for expanding the program 
memory with up to 3072 additional bytes of external memory, making a total program 
memory of 4096 (4k) bytes possible. (For details on how to implement program memory 
expansion, see the MCS-48 Microcomputer User' s Manual.) 


The external program memory is treated in the same manner as in the 256 byte pages (see 
Paragraph 3-8). There is, however, an additional condition which must be observed when 
program memory exceeds 2048 bytes. This is the Memory Bank (MB) address bit, the most 
significant bit in the 12-bit program counter. (Details on how the MB bit is manipulated are 
given in Paragraph 3-17.) 
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3-14. External Data Memory. If the data requirements of an application exceed the 
capacity of the on-chip 64 bytes of register memory, up to 256 bytes of external data 
memory can be added. This external data memory is accessed through the accumulator, 
using one of the RAM pointers for addressing. (Complete hardware details for data memory 
expansion are given in the MC^ -48 Microcomputer User's Manual. The instructions which 
read and write the external data memory are discussed in Paragraph 3-17). 
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3-15. External Ports. The most efficient means of I/O expansion for small MCS-48 
systems is the 8243 I/O Expander Device (part of Intel’ s compatible MCS -48 family) which 
requires only 4 port lines (the lower half of Port 2) for communication with the MCS-48 
Chip-Computer, The 8243 contains four 4-bit VO ports which serve as extensions of the 
on-chip I/O and are referred to in software as P4-P7. The following operations may be 
performed on these ports: 

1 . Transfer Accumulator Data to Port 

2. Transfer Port Data to Accumulator 

3. AND Accumulator to Port (result in Port) 

4. OR Accumulator to Port (result in Port) 


All communication between the MCS-48 Chip-Computer and ports P4-P7 takes place 
through the Least Significant Nibble of Port 2 (LSN P2). LSN P2 corresponds to pins 
P20-P23 on the Chip-Computer. Data is transferred between the LSN of the Accumulator 
and the specified port (P4-P7). A 4-bit transfer from one of these ports to the LSN of the 
Accumulator sets the Most Significant Nibble (MSN) of the Accumulator to zero. 


Hardware details as well as other options for port expansion are given in the MCS-48 
Microcomputer User’s Manual. The use of related software instructions is discussed in the 
MCS-48 Assembly Language Manual. 


3-16. Data Paths 

We have now introduced all the architectural features on the MCS-48 chip-computers. 
These features are the: 


a. Accumulator, 

b. Register Memory (with Working Registers, RAM Pointers, and Data Storage 
Registers), 

c. Program Counter and Program Memory, 

d. Stack and Flags, 

e. Timer/Event Counter, 

f. Input/Output Ports, and 

g. External Data Memory, Program Memory, and I/O Ports. 


The MICROMAP below shows the path that data can take between these processor 
elements. In this and in the MICROMAPS to follow, a single line denotes a data path on 
which data can flow in either direction, and a line with an arrow on one end stands for a data 
path on which data can only flow in the direction of the arrow. 


Paragraph 3-17 discusses the instructions which facilitate movement along the various 
MCS-48 data paths, as well as all other instructions available to the MCS-48 programmer. 
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3-17. MCS-48 Instruction Set 

In this section we will describe the various classes of instructions which allow data to be 
manipulated in the MCS-48 Chip-Computers. (For details of any specific instruction, we 
refer you to the MCS-48 and UPI-41 Assembly Language Manual, or the summaries in the 
MCS-48 Microcomputer Usefs Manual.) 


Roughly, the MCS-48 instructions break down into four categories: 

1 . Accumulator Instructions 

2 . Register- Accumulator Instructions 

3. Input/Output Instructions 

4. Control Instructions 


The Micromaps which illustrate these four categories use the following terminology: 

ROT represents any one of the working registers, RO, R1 , . . . , R7, in either Working 
Register Bank RBO or RBI . (Which bank depends on the status of the BS flag bit.) 

ROl can be any of the four RAM pointers, RO, Rl (Register Bank 0), and RO, R1 
(RBI). 

@R01 is the data memory location pointed to by the current register ROl; that is, the 
two-hex-digit contents of RO 1 represents the register number in register memory , or the 
address in external data memory. 

P12BUS represents Port 1, Port 2, or BUS (Port 0), the three .ports implemented 
on-chip in the MCS-48 family. 

P47 represents Port 4, 5, 6, or 7, the external I/O ports which can be added with very 
little additional hardware. 


3-18. Accumulator Instructions 

Instructions which allow the manipulation of data already in the accumulator are called 
Accumulator Instructions, and are shown in the Micromap below: 


3-19. Register Accumulator Instructions 

Register Accumulator Instructions are those which allow the manipulation of data already in 
a register of register memory, or the transfer of data between the accumulator and either 
register memory, the flags register, or external data memory. Also included are instructions 
which move data from program memory into the accumulator, and those instructions which 
affect the various flags. 


3-20. Input/Output Instructions 

The Input/Output Instructions are those which transfer data between the accumulator and an 
I/O Port, or which in some way affect either the port or the data transferred through it. The 
Timer/Event Counter is considered as a programmable I/O device which generates an 
interrupt or which sets a flag when full, and whose contents are transferrable to the 
accumulator. 
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3-21. Control Instructions 

Control Instructions are those instructions which allow the execution of non- sequential 
instructions; that is, instructions executed in an order other than that in which they are stored 
in program memory. Included in this category are jump instructions, conditional-jump 
instructions, and subroutine call and return instructions. 


3-22. Conclusion 

Now that we have progressively demonstrated the architectural features, data paths, and 
instruction set of the MCS-48 Chip-Computers, we can present the completed Micromap, 
which appears in enlarged two-page format immediately following. Then, on the next 
following page, a complete instruction set summary for the MCS-48 family is given in table 
form. Again, we refer you to the other manuals in the PROMPT-48 documentation package 
for further instruction set details. 
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CHAPTER 4 
HOW THE PROMPT 48 WORKS 


4-1. Introduction 


As a complete low cost microcomputer design aid, the Prompt 48 requires many more 
features, both hardware and software, beyond the MCS-48 Chip-Computer itself, which the 
user mounts in an external Execution Socket. Besides the 8748 or 8035 execution processor, 
the Prompt box contains: 


• 27 -key front panel for Data/Control input 

• An eight-character, 7-segment LED display (results/status out) 

• Power supply 

• Ik byte writable Program Memory (used in place of on-chip EPROM) 

• 256 bytes of processor-external Data Memory 

• An EPROM programmer, with external Programming Socket 

• Bus and Port expansion capability for additional user memory or peripheral devices 

• A serial port allowing for interface to an external terminal (TTY or RS-232) 

• Hardware and Monitor firmware (4k bytes) to provide such services as Examine/ 
Modify of Registers or Memory, and real-time execution of user programs with 
Single Step and Breakpoints. 


The hardware features of the Prompt 48 are shown in functional block diagram form in 
Figure 4-1. 


A few of the full capabilities of the MCS-48 Chip-Computer are restricted in the Prompt 
environment. This is due to design tradeoffs necessary to provide the full versatility of 
Prompt’s features and functions. It is possible to work around these restrictions, which 
disappear once the development cycle is complete and the user system stands and runs 
alone, provided that you are aware of them in advance. In the course of the development in 
this chapter, they will be pointed out when appropriate, and summarized in Paragraph 4-9. 


4-2. Hardware Description 

All Prompt 48 circuitry is located oh a single circuit board mounted on the inside of the front 
panel. A functional block diagram of this circuitry is given in Figure 4-1. 
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Figure 4-1. Functional Block Diagram 
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4-3. Memory 

The memory in Prompt 48 consists of five different types: 

a. Ik bytes read-only Program Memory internal to the 8748 or 8048 Chip-Computer 

b. 4k bytes Monitor Firmware (program Memory, read-only) 

c. Ik bytes writable Program Memory 

d. 256 bytes User Data Memory 

e. 256 bytes Monitor Data (Scratchpad) Memory 


4-4. Program Memory 

In the list above, the first three physical memories are program store memory, amounting to 
a total of 6k bytes. The MCS-48 Chip -Computer has a total addressing range in Program 
Memory of 4k bytes ( 1 2 address bits) . The user can expand the writable Program Memory of 
the Prompt (item 3 above) up to the 4k limit by configuring his own external hardware via 
the Bus Connector (Jl) and flat ribbon cable. If this were done, the Prompt ultimately would 
have to arbitrate Program Memory requests across a total range of 9k bytes, with a CPU 
whose address range is only 4k. This is accomplished indirectly in Prompt through “access 
codes.” The user has at his disposal six access codes which he can enter through the 
appropriate Command Function on the keyboard (see Paragraph 5-13). For systems equip- 
ped with the 6MHz upgrade package, there are twelve access codes, including the six 
originals; refer to appendix J. Besides the user’s access codes, the Monitor can map 
Program Memory in still another way. These seven access modes are summarized in the 
diagram below. 


4K 


3K 


2K 


IK 


0 


MONITOR 

MODE 


SYSTEM 

I/O 

AND 

SYSTEM 

MONITOR 

SUBROUTINES 


SYSTEM 

MONITOR 

KERNEL 


USER MODES 


ACCESS 

5 

ACCESS 

4 

ACCESS 

3 

ACCESS 

2 

ACCESS 

1 

ACCESS 

0 

SYSTEM 

I/O 

AND 

SYSTEM 

MONITOR 

CALLS 

EXPANSION 

MEMORY 

AND 

I/O 

OUTSIDE 

BOX 

OUTL PO 
(BUS) 

USES 

BUS AS 

PORT 

NO 

SYSTEM 

OR 

EXTERNAL 

MEMORY 

EXPANSION 

SYSTEM 

I/O 

AND 

SYSTEM 

MONITOR 

CALLS 

EXPANSION 

MEMORY 

AND 

I/O 

OUTSIDE 

BOX 

OUTL PO 
(BUS) 

USES 

BUS AS 

PORT 

NO 

SYSTEM 

OR 

EXTERNAL 

MEMORY 

EXPANSION 

READ 

READ 

READ 




ONLY 

ONLY 

ONLY 

WRITABLE 

WRITABLE 

WRITABLE 

ON CHIP 

ON CHIP 

ON CHIP 

IN BOX 

IN BOX 

IN BOX 

EPROM 

EPROM 

EPROM 

RAM 

RAM 

RAM 

(8748) 

(8748) 

(8748) 





FFF 


COO 

BFF 


800 

7FF 


400 

3FF 


000 


4-3 






How the Prompt 48 Works 


Prompt 48 


4-5. Data Memory 

Prompt 48 has 256 bytes of internal Data Memory locations, not including the 64 on- 
chip Register Memory locations, available to the user as “External Data Memory,” via 
the MOVX instructions. 

External Data Memory can be examined and modified from the panel controls and displays, 
through the resources of the Monitor; the address range is from 0 to FFig. In software, 
however, this Data Memory cannot be operated upon directly, like the working registers, or 
indirectly, like the remainder of on-chip Register Memory. To be operated upon, data from 
External Data Memory must first be moved into the accumulator by the use of the Move 
External Data Memory (MOVX A, (^ROl) command. This command does make use of 
indirect addressing via any of the four RAM pointer registers. 

Similar to the Program Memory, the Data Memory space allotment is controlled by user 
selection in the user mode, and by hardware/firmware selection in Monitor mode. As a 
result, the user may select via the Access Code, whether the memory space above SFFig is 
to be expansion Data Memory or Monitor I/O functions. When neither expansion Data 
Memory or I/O is selected, the user need not be concerned with any address space above 
3 FFi 6. But if it is selected, apage addressing scheme above 3FFie must be used, with Port 2 
LSNibble used to select page number. 


4-6. Input/Output 

All I/O pins of the Execution Socket processor (MCS-48) are accessible via the VO Ports 
and Bus Connector (Jl) on the front panel of the Prompt, allowing the user to take full 
advantage of the Input/Output power of the MCS-48 Chip -Computer. But a great deal of I/O 
capability is already resident to Prompt as delivered: the full range of Command Functions 
described in Chapter 5 on Panel Operation are provided as inputs to the system by the 
firmware Monitor, together with the corresponding display outputs of status and data. 

There is also a serial I/O option for Prompt, allowing communication with the system via a 
Teletype or RS-232C terminal. The installation of this option is described in Paragraph 
6-14. 


4-7. Monitor Firmware Description 

The Prompt 48 System Monitor resides in 4k of non-volatile memory and is automatically 
activated by a bootstrap routine on power-up or System Reset. The Monitor is responsible 
for all maintenance of keyboard and display, and provides the full range of Command 
Functions as described in Chapter 5, “Panel Operation.” A complete source code listing is 
included in the documentation package provided with the Prompt. This listing is self- 
documenting, including a rigorous structure definition of each Command Function in 
Backus -Normal Form. However, to make use of the powers of the Monitor, it is unneces- 
sary to understand the listing. 

Included in the Monitor firmware are a series of routines known as System Calls. These are 
general utility routines such as “read the keyboard’ ’ and “display character’ ’ which you the 
user are likely to find useful. In order to prevent unnecessary “re-invention of the wheel,” 
these System Calls are made available to the user, and described in Appendix B . Note that 
Access Code 2 or 5 must be selected in order to access the Monitor memory where the 
System Calls reside. 
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4-8. Bus Expansion 

In order to allow the user to expand the standard capabilities of the Prompt, some bus 
expandability has been included in the design. Bus expansion allows the addition of more 
Program Memory, more Data Memory, and the use of the 8243 I/O expansion chip. With a 
few exceptions, all bus lines and control signals are present on the J 1 connector on the front 
panel of the Prompt (labled Bus Connector; a pin list for this connector is given in Table 
4-1 .) The lines not provided include EA (External Address), SS (Single Step), XI and X2 
(clock inputs), and there is a limitation on the bidirectionality of the LSNibble of Port 2. Due 
to the multipurpose nature of the LSNibble of Port 2 and the Bus, care must be exercised 
when interfacing to these ports to insure that the Access Code, P2 map, and external 
circuitry do not allow the Prompt interface drivers to compete with the user’s drivers. (See 
Paragraph 6-14 for details.) In all cases, the user must instruct the Prompt as to the 
configuration of the system, including what type of expansion is desired. Since the EA line 
is not available, all user external Program Memory must reside above Ik. For hardware 
reasons, externally mapped Data Memory must be above Ik as well, though the External 
Data Memory provided by Prompt may be used from O-FFig. (LSNibble of Port 2 is used for 
mapping user- added external Data Memory.) 


Table 4-1. Pin List for I/O Ports and Bus Connector 


Signal Name 

Pin No. 

Buffer Characteristic 

BUS (0) 

17 ^ 



(1) 

21 



(2) 

25 



(3) 

29 



(4) 

31 


3-STATE BIDIRECTIONAL 

(5) 

27 



(6) 

23 



BUS (7) 

19 J 



PORT1 (0) 

18 V 



(1) 

20 



(2) 

22 



(3) 

24 

> 

8748 PSEUDO BIDIRECTIONAL 

(4) 

26 


CHIP (NO BUFFER) 

(5) 

28 



(6) 

30 



(7) 

32 


PORT 2 (0) 

7 'J 




1 


3-STATE MAPPED BIDIRECTIONAL 

(1) 

5 


with 100 a IN SERIES 

(2) 

3 

1 


(3) 

1 



PORT 2 (4) 

4 ^ 



(5) 

6 1 


8748 PSEUDO BIDIRECTIONAL 

(6) 



CHIP (NO BUFFER) 

(7) 

10 j 


* 

+ALE 

13 

TTL OUTPUT (10 

+T0 

14 

CHIP BIDIRECTIONAL (CLOCK), 2.2K Pullup 

+T1 

12 

CHIP INPUT, 2.2K input 

-INT 

49 , 

1 TTL LOAD (MON. GATED) 

-PSEN 

15 

1 


-RD 

9 


TTL OUTPUT (10 LS LOADS) 

-WR 

11 , 

1 


-PO WRITE 

33 

TTL OUTPUT (5 LS LOADS) 

-PROG 

2 

CHIP OUTPUT (NO BUFFER) 

-RESET 

16 

CHIP INPUT/OUTPUT (SYS RESET OVERRIDES), 2.2K pullup 

GND 

45, 46 

Ground 


47, 48 
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4-9. Restrictions 

A few of the full capabilities of the MCS-48 Chip -Computer are restricted in the Prompt 
environment. This is due to design tradeoffs necessary to provide the full versatility of 
Prompt’s features and functions. It is possible to work around these restrictions, which 
disappear once the development cycle is complete and the user system stands and runs 
alone, provided that you are aware of them in advance. 

Monitor Reentry Uses Stack: When the MON INT key is pressed, the Monitor program 
interrupts the user program, using one stack entry . If the user has calculated his stack needs 
only for his own subroutines and interrupts, and has stored other data on the next available 
stack location , that data will be ‘ ‘ zapped’ ’ (overwritten) by the user program return address . 

Unsupported Instructions: ANL BUS, A and ORL BUS, A will not work except in Access 
Mode 3 and then with the GO/NO BREAK command. OUTL BUS, A can only be used in 
Access Modes 0 and 3. 

Monitor Reentry Code: The upper 16 bytes of the lower Ik block of program Memory 
(addresses 3F0i6 through 3FFi6) must be reserved for the Prompt 48 Monitor reentry code. 
This code is automatically placed in Program Memory by the [7] Program PROM com- 
mand. (See Paragraph 5-50.) These bytes must also be reserved when using the RAM 
Program Memory inside Prompt 48. 

Access Code, P2 Map, LSN P2 Relationship: Care must be taken to insure that these three 
things are in agreement, as described in Paragraphs 5-13, 5-15, and 6-14. 

Timer Routines: The Timer Interrupt is disabled when using the GO/WITH BREAK and 
GO/SINGLE STEP commands . To debug timer routines , insert JTF (Jump if Timer Flag = 
1) in the program loop. 
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CHAPTER 5 
PANEL OPERATION 



5-1. Panel Description 

The panel of the Prompt-48 provides the means for the user to communicate with the 
computer. Commands and data are entered through keys on the panel, and status and data 
are displayed through panel indicators . Figure 5-1 shows the layout of the Prompt-48 panel . 
It is divided into two functional control groups, and also has two 40-pin sockets: one a 
programming socket used for programming 8748s or 8741s, and the other an execution 
socket which holds the 8035, 8048 or 8748 processor which functions as the system’s 
controller. In addition, there is a 50-pin flat cable connector which gives access to the 
executing processor’s input/output ports and bus for a user prototype circuit. 

5-2. Command Function Group 

5-3. Display. The display device on the Prompt-48 consists of 8 seven-segment LED 
digits, together with LED periods between digits. These 8 digits are used to display 
hexadecimal information in three fields: Function (2 hex digits). Address (3 hex digits), and 
Data (3 hex digits). The system monitor (the program which reads user information input 
through the keys and displays information to be output in the LEDs) displays information 






Figure 5-1. Prompt 48 Panel Layout 
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relevant to the current command being executed in these three fields. The LEDs are also 
available to user programs as output devices through the use of subroutines contained in the 
system monitor. 


C b' tl B B B 9 tl 

I FUNCTION I ADDRESS 1 DATA | 


5-4. Command Keys. The keys in this eight*key group are used by the user to enter 
commands to the monitor program. Entering a command causes the monitor to display a 2 
digit command code in the function field of the display. 


COMMANDS 


GO 

□ 

O 

EXAMINE 

/MODIFY 

NO| PROGRAM 
BREAK 1 MEMORY 

O 

O 

REGISTER 

WITH 1 DATA 

BREAK 1 MEMORY 

O 

O 

ENTRY 1 PREVIOUS 

NEXT 

Q 

G 

EXECUTE 

/END 


5-5. Hex Data/Functions Keys. This group of 16 keys, each representing a hex digit, is 
used to enter address and data parameters to the monitor program, to be used in the 
execution of the various commands. Some keys are also used to specify commands in 
addition to those specified through the commands keys. 


HEX DATA FUNCTIONS 


© 

© 

© 

0 

0 

0 

0 

0 

0 

© 

0 

0 

r 

□ 

00 

0 

© 

© 


5-6. Reset/Interrupt Group 

There are three keys on the Reset/Interrupt Group. These are the SYS RST (System Reset), 
MON INT (Monitor Interrupt), and USR INT (User Interrupt) keys. 
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The SYS RST (System Reset) key is used to reinitialize the system hardware, reset the 
Access Mode to 0, and give control to the Prompt-48 monitor program. After actuating the 
SYS RST key, the ACCESS = 0 prompt should appear in the LED display. 

The MON INT (Monitor Interrupt) key is used to interrupt the current process (user 
program) and turn over control to the monitor program so that its various functions are 
available. The interrupted user program can be continued later, as the user program status is 
saved by the Monitor program. 

The USR INT (User Interrupt) key causes the Prompt-48 CPU to save its current program 
address and status on the stack and begin execution at program memory location 003, if 
interrupts have previously been enabled with the EN I instruction. 


5-7. I/O Ports and Bus Connector (Jl) 

The I/O Ports and Bus Connector (Jl) is provided to allow Prompt to exchange data with 
your external prototype device. It allows expansion of the Prompt-48 program memory, 
data memory, and I/O ports to the full capacity of the MCS-48 family. Details of hardware 
expansion through the I/O Ports and Bus Connector are given in Paragraph 6-14. 
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5-8. Execution Socket 

The Execution Socket is a 40-pin zero insertion force socket in which resides the 8748, 
8035, or 8048 chip-computer used to control the Prompt-48. The CPU chip in this socket 
runs the monitor and user programs specified by the user. 
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5-9. Programming Socket 

The Programming Socket is a 40-pin zero insertion force socket which is used to program 
the Ik bytes of EPROM program memory in an 8748. It can also be used to program an 
8741 , or with an adapter (Prompt-475) to program an 8755. Another use of the Program- 
ming Socket is to read or verify the contents of any of these EPROM devices. 
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LOCKED 



SOCKET 

^WWWWWW^ 

8048 ’s should not be used in the Programming Socket as it is designed for use 
with EPROMS only. 

^AAAAAAAA 

MOS devices such as these are sensitive to transients or static electricity. 
It is possible to destroy their circuits by careless handling, especially if you 
are working in a carpeted area or in extremely low humidity conditions. 
Keep MOS devices in their protective packages when not in use. It is a 
good idea to touch the grounded frame of the computer with your hand 
before you place the EPROM device in the Programming Socket. This is to 
keep the pins of the device from being the first to touch and thereby absorb 
any static charges on your body. 


5-10. Command Description Formats 

In the following sections is described the various operating features of the Prompt -48 and 
how to use them. These features are accessible through the use of monitor commands. Each 
command is described with a command key sequence, those keys which must be pressed to 
call up the command, the state of the LED display when the command is specified, and 
ranges for all the parameters required by the individual command. 

The command key sequence is the sequence of keys which must be pressed starting from a 
command prompt, and continuing through to the next command prompt (see Paragraph 
5-12). The keys are indicated with square brackets: [NEXT] stands for the key in the lower 
left comer of the Commands keys. Key indications with capital letters, such as [GO], 
[PREVIOUS], or [D], stand for actual keys on the Prolnpt-48 panel. Key indications with 
lower case letters stand for command input parameters: [data] would stand for some element 
of information needed by the command, and input through the Hex Data keys. 

Keys with multiple names appear in key indications using the name best fitting the context in 
which they appear. For example [EXECUTE], [END], and [.] all stand for the same key, 
but since this key is used in slightly different ways at different times, multiple names are 
used. 
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The command description sections conclude with a short example of the appropriate 
command. 


5-11. Command Input Options 

The PROMPT Monitor is capable of accepting any of the commands from either of two 
sources: the keyboard, or the serial port. Following power-up, both devices are polled. The 
first one to send an input will be assigned as console until the next [SYS RST]. An input is 
defined as any keystroke for the keyboard, and as a non-null character for the serial port. 
The first serial character will be discarded while the keyboard first character will be 
accepted. When the serial port is selected, only handshaking signals are transmitted by 
PROMPT. These include a prompting character to request each byte of data at 

monitor level, a character request [“?”] to request each byte of input data, and an error flag 
[“e”] if any command or character is unacceptable. Otherwide, data may be requested of 
the system by the standard dump command, which will output to the serial port in the usual 
manner (and in HEX record format). 

It is important to note that the Monitor is looking for Hexidecimal, not ASCII codes . For this 
reason a Teletype keyboard, which generates ASCII coded data, is not really an effective 
substitute for the Prompt panel as an input device for commands. For example, the Fetch 
command is implemented by hitting an “F’ ’ on the Hex keypad of the Prompt. Inputting an 
“F” on the Teletype keyboard would result in a completely different code which the 
Monitor would not recognize. The usual reason for connecting a Teletype through the serial 
port would be to use it as a storage device (paper tape) and a hardcopy device (DUMP 
Program Memory, etc.). 


5-12. Commaiid Prompts 

The command prompts are displayed in the command function group display to indicate to 
the user that the Prompt-48 monitor program is ready to accept a command. There are two 
command prompts: 

ACCESS = 0 


The first prompt (ACCESS = 0) is given only when power is turned on or when the system is 
reset by pressing the SYS RST key. The second prompt (a dash on the display) is given 
subsequently to indicate the completion of a command and the system’s readiness for the 
next command. 


5-13. Access Mode Control 

The Access Mode defines the configuration of the various memory and input/output features 
of the Prompt-48. The proper setting of the Access Mode is therefore critical to the 
operation of the Prompt -48. 

Tw^o things are specified by the Access Mode: which program memory is to be used, and 
how the Bus input/output port (port 0) is used. There is, in addition to the Ik bytes of 
program memory on the MCS-48 Chip -Computer, an additional Ik bytes of RAM memory 
in Prompt -48. This memory can be used in place of the Ik bytes of on-chip program 
memory for purposes of easy program development and modification. When using an 8035 
in the execution socket, this is the only program memory available within Prompt -48. The 
Bus I/O port can be used in three ways: 

a. As a port, latched on output. Under this mode OUTL BUS, A will work. However, 
ANL BUS ,#data and ORL BUS,# data are not supported by Prompt -48 (refer to Para- 
graph 4-9.); 
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b. As a bus, to address expansion memory and I/O ports outside the Prompt-48 box; or 

c. As a bus, to address the Prompt system monitor memory and I/O devices rather than 
any external hardware. This mode would be used if your user program wanted to talk 
directly to the Prompt keyboard, displays or serial channel. A listing of the system 
monitor program is included with your Prompt -48, and the use of some of its routines 
is described in Appendix B: System Calls. 


5-14. Access Mode Select Command. The format of the Access Mode Select Command 
is as follows: 

Command Key Sequence: [A] [data] [.]* 

Function Display: “Ac. . 00“ 

Data Range: 0-5 


Table 5-1. Summary Table of Access Mode Codes 


Code 

Program Memory 

Bus Option 

0 

RAM 

See Paragraph 5-1 3a 

1 

RAM 

See Paragraph 5-1 3b 

2 

RAM 

See Paragraph 5-1 3c 

3 

On-chip ROM/ 

EPROM 

See Paragraph 5-1 3a 

4 

On-chip ROM/ 

EPROM 

See Paragraph 5-1 3b 

5 

On-chip ROM/ 

EPROM 

See Paragraph 5-1 3c 


*EXECUTE/END key. 


Example: Set Access = 0. The key sequence is [A] [O] [.]. Alternately, [SYS RST] sets 
Access = 0, as well as resetting various other system parameters. 

The access codes are presented in a different format in Table 5-2. 


Table 5-2. Access Code/P2 Map Summary 


Access 

Code 

Program Memory 

System 

I/0& 

Calls 

Expansion 
Memory 
& I/O 

OUTL 

Porto 

Allowed 

LSN P2 Map 

0 

RAM 

No 

No 

Yes 

output (0) only 

1 

RAM 

No 

Yes 

No 

input or output 

2 

RAM 

Yes 

No 

No 

output only 

3 

On-chip 

ROM/EPROM 

No 

No 

Yes 

input or output 

4 

On-chip 

ROM/EPROM 

No 

Yes 

No 

input or output 

5 

On-chip 

ROM/EPROM 

Yes 

No 

No 

output only 


Prompt 48 
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5-15. Port 2 and Port 2 Mapping 


In an MCS-48 Chip -Computer, the Least Significant Nibble (LSN) or Port 2 (P2) is used for 
a variety of functions. It is at various times an Input/Output port, a Data Memory page 
select, the Most Significant Nibble (MSN) of the Program Memory address, or some 
combination of these. In the case of Prompt -48, the monitor must be able to use the memory 
expansion capabilities, and yet at the same time allow the user to specify input/output, etc. 
To accomplish this, the port must be buffered. But in order to buffer, the direction of 
buffering must be specified. This is accomplished with the P2 Map. 

The P2 Map is therefore nothing more than a bit-by-bit specification of the buffer direction 
of the corresponding bits of P2, with 1 == Input, and 0 = Output. 

As mentioned above, MCS-48 Chip -Computers use the LSN P2 to address off-chip 
(expansion) Program Memory and I/O ports. The Access Code (see Paragraph 3-13) 
specifies the configuration and location of the various expansion memories and ports. Thus, 
in Prompt-48, the LSN P2 Map, the Access Code, and the contents of LSN P2 are all 
related. Furthermore, under some Access Codes, certain LSN P2 Maps could cause 
conflicts, and the Chip-Computer would not work! Be sure to carefully study the following 
information and the table which summarizes it. 

With Access Codes 0, 2, or 5, LSN P2 Map must be output (0). In these modes LSN P2 is 
used by the monitor program to select various internal memories in the Prompt -48 and must 
not be affected by input devices. 

Access Codes 1 or 4 allow LSN P2 Map to be either input or output. In these modes, the user 
program selects various external memories, I/O devices, and/or external ports which the 
user may have connected to the I/O Ports and Bus Connector, J 1 . The P2 Map is bypassed in 
these modes and therefore immaterial. 

Access Code 3 also allows LSN P2 Map to be either input or output. Expansion memory and 
I/O ports are not allowed in this mode, and both P2 and Bus (PO) are available as I/O ports 
through Jl. 

This information is summarized in table 5-3, which also appears as Appendix I: 


Table 5-3. Access Code/LSN P2 Map Summary 


Access 

Code 

Program Memory 

System 

I/O & 
Calls 

Expansion 
Memory 
& I/O 

OUTL 

Porto 

Allowed 

LSN P2 Map 

0 

RAM 

No 

No 

Yes 

output (0) only 

1 

RAM 

No 

Yes 

No 

input or output 

2 

RAM 

Yes 

No 

No 

output only 

3 

On-chip 

ROM/EPROM 

No 

No 

Yes 

input or output 

4 

On-chip 

ROM/EPROM 

No 

Yes 

No 

input or output 

5 

On-chip 

ROM/EPROM 

Yes 

No 

No 

output only 
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5-16. Port 2 Map Command. The format of the Port 2 Map Command is as follows: 

Command Key Sequence: [2] [data] [.] 

Function Display: “P2. .MM” 

Data Range: MMig where MM are two hexadecimal digits chosen to map the eight lines 
of P2 according to table 5-4. 


Table 5-4. Port 2 Map Command Data Bits Vs. Port 2 Pin Numbers 


MS Nibble 

LS Nibble 


Bite 

Bite 

Bit 4 

Bits 

Bits 

Bit 1 

BitO 

Pin P27 

Pin P26 

Pin P25 

Pin P24 

Pin P23 

Pin P22 

Pin P21 

Pin P20 


A hexadecimal/binary conversion is given in table 5-5. 0 = Output, 1 = Input. 


Table 5-5. Hexadecimal/Binary Conversion 


Hex 

Binary 

0 

0 

0 

0 

0 

1 

0 

0 

0 

1 

2 

0 

0 

1 

0 

3 

0 

0 

1 

1 

4 

0 

1 

0 

0 

5 

0 

1 

0 

1 

6 

0 

1 

1 

0 

7 

0 

1 

1 

1 

8 

1 

0 

0 

0 

9 

1 

0 

0 

1 

A 

1 

0 

1 

0 

B 

1 

0 

1 

1 

C 

1 

1 

0 

0 

D 

1 

1 

0 

1 

E 

i 1 

1 

1 

0 

F 

I 1 

! 

1 

1 

1 


Example: Set P2 Map = OOie (all lines of P2 mapped as outputs). The key sequence is 

2 .]. 


It should be noted that Port 2 is treated by the monitor as ‘ ‘register’ ’ 47 and can be examined 
and/or modified through the Examine/Modify Register command (see Paragraph 5-17). 
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5-17. Examine/Modify Commands 


5-18. Examine/Modify Pregrani Memory Command. The format of the Examine/ 
Modify Program Memory Command is as follows: 

Command Key Sequence: [EXAMINE/MODIFY] [PROGRAM MEMORY] 

[address] [NEXT] [data] [NEXT] [data] ...[.] 


Function Display: “EP. . ” 

Address Range: O-FFFie 
Data Range: 0-FFie 

The Examine/Modify Program Memory command is used to examine and/or modify one or 
more Program Memory locations. An address in Program Memory is specified, and 
optional data is input if desired to replace the existing data displayed in the DATA field of 
the LEDs. The next greater address in Program Memory can be examined by then pressing 
the [NEXT] key, or the next lesser address can be examined by pressing the [PREVIOUS] 
key. Return to command prompt is accomplished by pressing the [END] key instead of 
another [NEXT] or [PREVIOUS]. The Program Memory accessed through this command is 
the RAM Program Memory in Prompt -48 and expansion Program Memory the user may 
have connected to J1 . To read the on-chip EPROM Program Memory of an 8748 or 8741 , 
the EPROM contents must first be read into RAM with the Prom Fetch command (see 
Paragraph 5-50). 

Example: Change Program Memory locations 3 A and 3B to contain 5C and E2, respec- 
tively. The key sequence is [EXAMINE/MODIFY] [PROGRAM MEMORY] 
[3] [A] [NEXT] [5] [C] [NEXT] [E] [2] [.]. This could also be accomplished by 
pressing [EXAMINE/MODIFY] [PROGRAM MEMORY] [3] [B] [NEXT] [E] 
[2] [PREVIOUS] [5] [C] [.], or by individually modifying locations 3 A and 3B 
in separate command sequences. 


5-19. Examine/Modify Register Command. The format of the Examine/Modify Regis- 
ter Command is as follows: 

Command Key Sequence: [EXAMINE/MODIFY] [REGISTER] [address] [NEXT] 

[data] [NEXT] [data] ...[.] 


Function Display: “Er. ” 

Address Range: 0-48i6 
Data Range: O-FFig 

This command allows the user to examine and optionally modify the 64 bytes of Register 
Memory on-chip with MCS-48 Chip -Computers. As with the other Examine/Modify 
commands, [PREVIOUS] may be substituted for any [NEXT] after the first to examine the 
previous register contents, or [.] may be substituted to terminate the command sequence. 

There are in Prompt-48 an additional 9 bytes of special-purpose “Register” memory, in 
address locations 40i6-48i6. These “Register” Memory locations represent other registers 
in the Chip -Computer, such as the Accumulator, etc. according to table 5-6. 
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Table 5-6. Special Purpose Register Memory Summary 



Ports 0 and 1 (“registers” 45 and 46) cannot be modified by the Examine/Modify Register 
command. They are read only. 


The bits of Prompt -48 Misc. (“register” 48) require some explanation: 

COUNTER RUN must be set to “ 1 ” if your program uses the MCS-48 timer/event counter 
as an event counter. This allows the monitor to suspend and restart the timer/event counter 
when a break in the user program occurs. 


During breaks the Prompt -48 monitor saves the state of the broken user program so that it 
can be restored as execution is resumed. 


TIMER RUN will be set to “ 1 ” on break if the timer is mnning . If you clear this bit to “0” 
the timer will not be restarted when execution is resumed. 


TIMER FLAG allows you manually to examine and modify the user timer flag. 


NESTED FROM INTERRUPT will be set to “1” if you have broken during a routine 
servicing an interrupt. This is a user state bit. 

WILL ENABLE INTERRUPT represents the user’ s interrupt enable state if user interrupts 
are enabled. 


MEM BANK is the Designated Bank. Flag (refer to paragraph 3-8). 


T1 and TO are the MCS-48 test inputs and are read only. 


Example: Change the contents of Register Memory location 2 A to be 49 le- The key 
sequence is [EXAMINE/MODIFY] [REGISTER] [2] [a] [NEXT] [4] [9] [.]. 
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5-20. Go Commands and Breakpoints 


5-21. Go/No Break Command. The format of the Go/No Break Command is as follows: 
Command Key Sequence: [GO] [NO BREAK] [address] [.] 

Function Display: “Go. 

Address Range: O-FFFig 

The Go/No Break command causes the MCS-48 Chip -Computer in the Execution Socket to 
begin program execution at the address in Program Memory given in the command 
sequence. Program execution will continue until either (1) control is returned to the monitor 
by pressing [MON INT], or (2) the system is reset and control given to the monitor by 
pressing [SYS RST]. The CPU runs at full speed. 

Example: Begin execution of a program in PROGRAM Memory which starts at IFOie- The 
key sequence is [GO] [NO BREAK] [1] [F] [0] [.]. 


5-22. Breakpoints. A breakpoint is a location in program memory which, when reached 
by the user program, causes control to be given to a monitor program. The state of the 
processor is saved so that the current user program can be continued at a later time. Control 
is then given to the monitor program so that the user can examine register contents , memory 
contents, and so forth as an aid to program development and debugging. 

The Prompt-48 monitor allows the user to specify up to eight breakpoints, numbered 0-7. 
When running with breakpoints enabled (using the Go/With Break command) the monitor 
single- steps the user program and checks after each step to see if a breakpoint address has 
been reached in Program Memory. If it has, the monitor program suspends stepping, saving 
the contents of all the MCS-48 registers, and displays information about which breakpoint 
was reached, the contents of the Program Counter, and the contents of the Accumulator. 
The monitor then allows the user access to all of the panel commands. If no other keys have 
been pressed, the user program may be restarted by pressing [NEXT]. If other keys have 
been pressed, one of the Go commands must be used. 

These breakpoints do not affect memory contents. They may even be set in non- writable 
ROM or PROM. 


5-23. Examine/Modify Breakpoint Command. The format of the Examine/Modify 
Breakpoint Command is as follows: 

Command Key Sequence: [B] [breakpoint number] [NEXT] 

[breakpoint address] [NEXT] 

[breakpoint address] [NEXT] 

...[.] 


Function Display: “br. . ’’ 

Breakpoint Number Range: 0-7 (Appears in ADDRESS display field) 

Breakpoint Address Range: O-FFFie (Appears in DATA display field) 

The Examine/Modify Breakpoint command operates in a manner similar to the Examine/ 
Modify Program Memory, Data Memory, and Register commands . In this case the address 
is the breakpoint number, and the data is the location in Program Memory where the 
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breakpoint resides. As with the other Examine/Modify commands [PREVIOUS] can be 
substituted for any [NEXT] after the first, or [END] can be substituted to terminate the 
command sequence. 

Example: Set Breakpoints 0 and 1 at Program Memory locations 106x6 3F2i6, respec- 

tively. The key sequence is [B] [0] [NEXT] [1] [0] [6] [NEXT] [3] [F] [2] [.]. 


5-24. Go/With Break Command. The format of the Go/With Break Command is as 
follows: 

Command Key Sequence: [GO] [WITH BREAK] [address] [.] 

Function Display: “Gb. . ” 

Address Range: O-FFFie 

The Go/With Break command single steps the MCS-48 Chip-Computer through the user 
program starting at the address in Program Memory given in the command sequence. 
Program single stepping will continue until either (1) [SYS RST] is pressed, (2) [MON INT] 
is pressed, or (3) a breakpoint is reached. Breakpoint information is displayed in the format, 

“bN.ADR. AC”, 

where N = the breakpoint number, ADR = the contents of the Program Counter (the 
breakpoint address), and AC = the contents of the Accumulator. The monitor then allows 
the user access to all of the panel commands. If no other keys have been pressed, the user 
program may be restarted by pressing [NEXT]. If other keys have been pressed, one of the 
Go commands must be used. 

Example: Begin execution of a program in Program Memory which starts at EOie, with 
breakpoints enabled. The key sequence is [GO] [WITH BREAK] [E] [0] [.]. 


5-25. Search Memory Commands 

The Search Memory commands allow the user to search Program Memory, Data Memory, 
or Register Memory for a one- or two-byte data pattern, called the search target. The 
commands which search for a one-byte search target are called Byte Search commands, and 
those which search for a two-byte search target are called Word Search commands. 

The format for each of the Search Memory commands is the same, as follows: 

[search type] [memory type] [starting address] 

[NEXT] [ending address] [NEXT] [search target] 

[NEXT] [mask] [EXECUTE] [NEXT] [NEXT] ...[.], 

where [search type] is [4] for a Byte Search or [5] for a Word Search; [memory type] is 
[PROGRAM MEMORY], [DATA MEMORY], or [REGISTER]; [starting address] and 
[ending address] define the area to be searched; [search target] is the object of the search; 
and [mask] is a bit pattern the same length as.[search target], which causes only those bits in 
[search target] which correspond to I’s in [mask] to be tested in the search. The sequence 
[NEXT] [mask] is optional and may be omitted. 

The [EXECUTE] key causes the search to commence. If no occurrences of the search target 
(as modified by the mask) are found in the specified memory range, the monitor returns to 
command prompt status. If the (modified) search target is found, the address of the 
occurrence and the data matching the (modified) search mask are displayed as follows: 

“SM.ADR. DD”, 
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where M is the memory type, ADRis the address in hexadecimal of the occurrence, and DD 
is the data matching the (modified) search target. After [EXECUTE] is pressed and data is 
found, [NEXT] may be pressed to reinitiate the search with ADR+ 1 as the new starting 
address. All other search parameters remain constant. 


5-26. Byte Search Program Memory Command. The format of the Byte Search Pro- 
gram Memory Command is as follows: 

Command Key Sequence: [4] [PROGRAM MEMORY] [starting address] 

[NEXT] [ending address] [NEXT] [search target] 

[NEXT] [mask] [EXECUTE] 

[NEXT] [NEXT] ...[.] 


Function Display: “SP. 

Address Range: O-FFFig 
Search Target Range: 0-FFie 
Mask Range: 0-FFie 

Note: [NEXT] [mask] and [NEXT] [NEXT] ... are optional and may be omitted. 

Example: Search Program Memory for the second occurrence of bCig or 6Di6 (01 101 IOO 2 
or 01 101 IOI 2 ) between the addresses lOOig and 2D0i6. This implies a mask of 
FE 16 (1 1 1 1 1 1 IO 2 ). The key sequence is [4] [PROGRAM MEMORY] [1] [0] [0] 
[NEXT] [2] [D] [0] [NEXT] [6] [C] [NEXT] [F] [E] [EXECUTE] [NEXT] [.]. 


5-27. Byte Search Data Memory Command. The format of the Byte Search Data 
Memory Command is as follows: 

Command Key Sequence: [4] [DATA MEMORY] [starting address] 

[NEXT] [ending address] [NEXT] [search target] 

[NEXT] [mask] [EXECUTE] 

[NEXT] [NEXT] ...[.] 


Function Display: “Sd. . ” 

Address Range: O-FFie 
Search Target Range: O-FFig 
Mask Range: 0-FFie 

Note: [NEXT] [mask] and [NEXT] [NEXT] ... are optional and may be omitted. 

Example: Search Data Memory between 00 and 4B le for the first occurrence of A9i6. The 
key sequence is [4] [DATA MEMORY] [0] [NEXT] [4] [B] [NEXT] [A] [9] 
[EXECUTE] [.]. 
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5-28, Byte Search Register Memory Command. The format of the Byte Search Register 
Memory Command is as follows: 

Command Key Sequence: [4] [REGISTER] [starting address] 

[NEXT] [ending address] [NEXT] [search target] 

[NEXT] [mask] [EXECUTE] 

[NEXT] [NEXT] ...[.] 


Function Display: “Sr. . ” 

Address Range: 0-48 ig 
Search Target Range: O-FFig 
Mask Range: O-FFig 

Note: [NEXT] [mask] and [NEXT] [NEXT] ... are optional and may be omitted. 

Example: Search Register Memory for the first occurrence of SXjg, where X signifies 
‘ ‘don’t care’ ’ . This implies a mask of FOie (1 1 1 IOOOO 2 ) . The key sequence is [4] 
[REGISTER] [0] [NEXT] [4] [8] [NEXT] [8] [0 or any other hex key] [NEXT] 
[F] [0] [EXECUTE] [.]. 


5-29. Word Search Program Memory Command. The format of the Word Search 
Program Memory Command is as follows: 

Command Key Sequence: [5] [PROGRAM MEMORY] [starting address] 

[NEXT] [ending address] 

[NEXT] [search target MSB] 

[NEXT] [search target LSB] 

[NEXT] [mask MSB] [NEXT] [mask LSB] [EXECUTE] 
[NEXT] [NEXT] ...[.] 


Function Display: “SP. . ” 

Address Range: O-FFFie 
Search Target Range: O-FFFFie 
Mask Range: O-FFFFie 

Note: [NEXT] [mask MSB] [NEXT] [mask LSB] and [NEXT] [NEXT] . . . are optional 
and may be omitted. 

Example: Search Program Memory for the first occurrence of A429i6. The key sequence is 
[5] [PROGRAM MEMORY] [0] [NEXT] [F] [F] [F] [NEXT] [A] [4] [NEXT] 
[2] [9] [EXECUTE] [.]. 


5-30. Word Search Data Memory Command. The format of the Word Search Data 
Memory Command is as follows: 

Command Key Sequence: [5] [DATA MEMORY] [starting address] 

[NEXT] [ending address] 

[NEXT] [search target MSB] 

[NEXT] [search target LSB] 

[NEXT] [mask MSB] [NEXT] [mask LSB] [EXECUTE] 
[NEXT] [NEXT] ... [.] 
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Function Display: “Sd. . ” 

Address Range: 0-FFie 
Search Target Range: O-FFFFig 
Mask Range: O-FFFFie 

Note: [NEXT] [mask MSB] [NEXT] [mask LSB] and [NEXT] [NEXT] ... are optional 
and may be omitted. 

Example: Search Data Memory between locations 19i6 for the first occurrence of 

3B14i 6. The key sequence is [5] [DATA MEMORY] [1] [9] [NEXT] [3] [F] 
[NEXT] [3] [B] [NEXT] [1] [4] [EXECUTE] [.]. 


5-31. Word Search Register Memory Command. The format of the Word Search 
Register Memory Command is as follows: 

Command Key Sequence: [5] [REGISTER] [starting address] 

[NEXT] [ending address] 

[NEXT] [search target MSB] 

[NEXT] [search target LSB] 

[NEXT] [mask MSB] [NEXT] [mask LSB] [EXECUTE] 
[NEXT] [NEXT] ... [.] 

Function Display: ‘‘Sr. 

Address Range: 0-48 le 
Search Target Range: O-FFFFie 
Mask Range: 0-FFFFie 

Note: [NEXT] [mask MSB] [NEXT] [mask LSB] and [NEXT] [NEXT] ... are optional 
and may be omitted. 

Example: Search Register Memory for an occurrence of A42Di6. The key sequence is [5] 
[REGISTER] [0] [NEXT] [4] [8] [NEXT] [A] [4] [NEXT] [2] [D] [EXECUTE] 
[•]. 


5-32. Move Memory Commands 

The Move Memory commands allow the user to move blocks of data from one area to 
another in any one of the three memory types: Program Memory , Data Memory , or Register 
Memory. Data cannot be moved from one memory type to another. 

The format for each of the Move Memory commands is the same, as follows: 

[9] [memory type] 

[source starting address] [NEXT] [source ending address] 

[NEXT] [destination starting address] [EXECUTE] 

where [9] is the Move Memory command; [memory type] is [PROGRAM MEMORY], 
[DATA MEMORY], or [REGISTER]; [source starting address] and [source ending ad- 
dress] define the block of data to be moved; and [destination starting address] defines the 
area of memory to which the data is to be moved. 
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The memory move is commenced by pressing [EXECUTE]. The Move Memory commands 
will move any block of memory data between any two memory areas of a single memory 
type. 


5-33. Move Program Memory Command. The format of the Move Program Memory 
Command is as follows: 

Command Key Sequence: [9] [PROGRAM MEMORY] 

[source starting address] [NEXT] 

[source ending address] [NEXT] 

[destination starting address] [EXECUTE] 


Function Display: “nP. . ” 

Address Range: 0-FFFie 

Example: Move the contents of Program Memory locations O-FFie to Program Memory 
locations ZTOig— 26Fi6. The key sequence is [9] [PROGRAM MEMORY] [0] 
[NEXT] [F] [F] [NEXT] [2] [7] [0] [EXECUTE] [.]. 


5-34. Move Data Memory Command. The format of the Move Data Memory Command 
is as follows: 

Command Key Sequence: [9] [DATA MEMORY] 

[source starting address] [NEXT] 

[source ending address] [NEXT] 

[destination starting address] [EXECUTE] 

Function Display: “nD. . ” 

Address Range: 0-FFie 

Example: Move the contents of Data Memory locations 6-2B iq to Data Memory locations 
Aie— 2Fie (move the block “up” in memory four bytes). The key sequence is 
[9] [DATA MEMORY] [6] [NEXT] [2] [B] [NEXT] [A] [EXECUTE] [.]. 


5-35. Move Register Memory Command. The format of the Move Register Memory 

Command is as follows: 

Command Key Sequence: [9] [REGISTER] 

[source starting address] [NEXT] 

[source ending address] [NEXT] 

[destination starting address] [EXECUTE] 

Function Display: “nr. . ” 

Address Range: 0-48 le 

Example: Move the contents of Register Memory locations 4-18ie to Register memory 
locations Aig- lEig. The key sequence is [9] [REGISTER] [4] [NEXT] [1] [8] 
[NEXT] [A] [EXECUTE] [.]. 
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5-36. Clear Memory Commands 

5-37. Clear Program Memory Command. The format of the Clear Program Memory 
command is as follows: 

Command Key Sequence: [C] [PROGRAM MEMORY] [starting address] 

[NEXT] [ending address] [.] 


Function Display: ‘‘CP. . ” 

Address Range: O-FFFig 

The Clear Program Memory command clears each memory location between and including 
the starting address and the ending address to OOie. 

Example: Clear Program Memory locations 0-3FFi6. The key sequence is [C] [PRO- 
GRAM MEMORY] [0] [NEXT] [3] [F] [.]. 


5-38. Clear Data Memory Command. The format of the Clear Data Memory Command 
is as follows: 

Command Key Sequence: [C] [DATA MEMORY] [starting address] 

[NEXT] [ending address] [.] 


Function Display: “Cd. . ” 

Address Range: O-FFig 

The Clear Data Memory command clears each memory location between and including the 
starting address and the ending address to OOig. 

Example: Clear Data Memory locations 20ie— 4Fi6. The key sequence is [C] [DATA 
MEMORY] [2] [0] [NEXT] [4] [F] [.]. 


5-39. Clear Register Memory Command. The format of the Clear Register Memory 
Command is as follows: 

Command Key Sequence: [C] [DATA MEMORY] [starting address] 

[NEXT] [ending address] [.] 

Function Display: “Cr. . ” 

Address Range: 0-48 ig 

The Clear Register Memory command clears each memory location between and including 
the starting address and the ending address to OOig. 

Example: Clear Register Memory locations 0- IFig. The key sequence is [C] [REGISTER] 
[0] [NEXT] [1] [F][.]. 


5-40. Dump Memory Commands 

Any data that can be accessed by the Examine/Modify Memory commands may be output 
through the serial port with these commands. The user may thereby save program, register, 
or data information on paper tape, or hard copy or other peripheral. The format is the 
hexadecimal Object File format, described in Appendix D. 
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If the command is received from the Prompt -48 keyboard, then the Hexadecimal Object File 
will be preceded and followed by a series of null characters for tape header and trailer. If the 
command is received via the serial channel, then the Hexadecimal Object File will be 
immediately dumped without any null insertion. 


5-41. Dump Program Memory Command. The format of the Dump Program Memory 
Command is as follows: 

Command Key Sequence: [D] [PROGRAM MEMORY] [starting address] 

[NEXT] [ending address] [.] 

Function Display: “dP. 

Address Range: O-FFFig 

Note: starting address must be less than or equal to ending address. 

Example: Dump Program Memory locations 0-3FFi6 through the serial port. The key 
sequence is [D] [PROGRAM MEMORY] [0] [NEXT] [3] [F] [F] [.]. 


5-42. Dump Data Memory Command: The format of the Dump Data Memory Com- 
mand is as follows: 

Command Key Sequence: [D] [DATA MEMORY] [starting address] 

[NEXT] [ending address] [.] 

Function Display: “dd. . ” 

Address Range: O-FFig 

Note: starting address must be less than or equal to ending address. 

Example: Dump Data Memory through the serial port. The key sequence is [D] [DATA 
MEMORY] [0] [NEXT] [F] [F] [.]. 


5-43. Dump Register Memory Command. The format of the Dump Register Memory 
Command is as follows: 

Command Key Sequence: [D] [REGISTER] [starting address] 

[NEXT] [ending address] [.] 


Function Display: “dr. . ” 

Address Range: 0-48 le 

Note: starting address must be less than or equal to ending address. 

Example: Dump Register Memory through the serial port. The key sequence is [D] 
[REGISTER] [0] [NEXT] [4] [8] [.]. 


5-44. Enter Into Memory Commands 

The Enter into Memory commands allow the user to load any file corresponding to the 
Hexadecimal Object File Format (Appendix D) from the serial port into Program Memory, 
Data Memory , or Register Memory . The parameters needed by the Enter commands are the 
memory type and an offset to the starting address given in the Object File. 
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5-45. Enter into Program Memory Command. The format of the Enter into Program 
Memory command is as follows: 


Command Key Sequence: [E] [PROGRAM MEMORY] [starting address offset] 

[.] 


Function Display: “rP. 


5-46. Enter into Data Memory Command. The format of the Enter into Data Memory 
command is as follows: 

Command Key Sequence: [E] [DATA MEMORY] [starting address offset] 

[.] 

Function Display: “rd. 

5-47. Enter into Register Memory Command. The format of the Enter into Register 
Memory command is as follows: 

Command Key Sequence: [E] [REGISTER] [starting address offset] 

[•] 

Function Display: “rr. . ” 


5-48. Hexadecimal Arithmetic Command 


5-49. Hexadecimal Arithmetic Command. The format of the Hexadecimal Arithmetic 
command is as follows: 

Command Key Sequence: [6] [x data] [NEXT] [y data] [EXECUTE] 

Function Display: “HE. . ” 

Data Range: 0-FFFie 

The Hexadecimal Arithmetic command performs hexadecimal addition and subtraction on 
two one-to-three digit hexadecimal numbers, x and y . Upon pressing [EXECUTE] the sum 
and difference are displayed in the following format: 

“HE.x+y.x— y”. 


5-50. EPROM Programming, Fetch, Compare Commands 


5-51. EPROM Programming Command. The EPROM Programming commands allow 
the user to program all or part of the EPROM Program Memory on an 8748 Microcomputer 
with EPROM, an 8755 EPROM Program Memory and I/O Expander, or an 8741 
Microcomputer with EPROM (UPI-41 family). 

There are two programming modes, one which does not insert the Prompt-48 byte reentry 
code, and one which does. 
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The mode which does insert this code is intended for 8748 ’s which are to be used in the 
Prompt -48 Execution Socket. The Prompt -48 16 byte reentry code is needed in Program 
memory to allow the Monitor program to properly transfer control to the user program. It 
occupies the 16 highest bytes of the lower 1024 bytes of Program Memory, locations 
3FOi0— 3 FFi 6. This programming mode is inappropriate for 8755’ s present via an adapter, 
and an error display will appear in the LED’s to indicate that the wrong mode has been 
selected. 


The programming mode which does not insert the reentry code copies the RAM Program 
Memory faithfully to the EPROM device in the Programming Socket. This mode will work 
for 874rs, 8748’s, and with the addition of a Prompt 475 adapter, 8755’s. 


The Prompt-48 will not attempt to program EPROM devies which have not had the 
appropriate locations completely erased. If an unerased location is detected an error display 
with the address and EPROM contents will appear. 


5-52. Program EPROM With Reentry Code Command. The format of the Program 
EPROM With Reentry Code command is as follows: 

Command Key Sequence: [7] [starting address] [NEXT] [ending address] 

[NEXT] [starting EPROM address] [EXECUTE] 

Function Display: “Pr 8748” 

Address Range: 0-3FFi6 


This command programs all or part of the EPROM Program Memory on an 8748 Micocom- 
puter with EPROM. The 16 byte monitor reentry code is automatically substituted for any of 
the 16 locations from 3F0i6 to 3FFi6. 


Example: Program the Prompt -48 RAM Program Memory into an 8748 intended for use in 
the Prompt-48 Execution Socket. First install the 8748 in the Programming 
Socket. The key sequence is [7] [0] [NEXT] [3] [F] [F] [NEXT] [0] [EXE- 
CUTE]. The display will blank to indicate that the EPROM is being programmed 
and the command prompt returns automatically after the EPROM has been 
successfully programmed. 


5-53. Program EPROM Without Reentry Code Command. The format of the Program 
EPROM Without Reentry Code command is as follows: 

Command Key Sequence: [3] [starting address] [NEXT] [ending address] 

[NEXT] [starting EPROM address] [EXECUTE] 

Function Display: ”Pr 8741” or ”Pr 8755”* 

Address Range: 0-3FFi6 

*with 475 adapter. 
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This command programs all or part of the EPROM Program Memory on the 8741 , 8748, or 
8755 (if a Prompt 475 adapter is installed). The function display “Pr 8741” appears for 
the 8741 and 8748, and (if the adapter is installed) the function display ‘Tr 8755” 
appears. With this command the RAM Program Memory is written to the EPROM device 
without modification. 

Example: Program the entire Prompt-48 RAM Program Memory contents into the EPROM 
device on an 8741. First install the 8741 into the Prompt -48 Programming 
Socket. The key sequence is [3] [0] [NEXT] [3] [F] [F] [NEXT] [0] [EXE- 
CUTE]. The LED display will blank to indicate that the EPROM is being 
programmed and the command prompt returns automatically after the EPROM 
has been successfully programmed. 


5-54. Compare EPROM Command. The format of the Compare EPROM command is 
as follows: 

Command Key Sequence: [8] [starting Prompt address] [NEXT] 

[ending Prompt address] [NEXT] 

[starting EPROM address] [EXECUTE] 

Function Display: “Co. . ” ?? 

Address Range: 0-FFFie (but not to exceed PROM capacity) 

The Compare EPROM command compares the specified areas of Prompt-48 RAM Program 
Memory and the EPROM device installed in the Programming Socket. Before specifying 
this command, an 8748, 8741 , or 8755 with 475 adapter must be installed in the Program- 
ming Socket. If no EPROM device or 475 adapter is present and locked, or the device is 
placed in the socket backwards, upon receipt of the [C] command the display will read out 
an error message. 

Example: Compare the contents of an 8748 installed in the Programming Socket with the 
RAM Program Memory in Prompt -48. The key sequence is [C] [0] [NEXT] [3] 
[F] [F] [NEXT] [0] [EXECUTE]. 


5-55. Fetch EPROM Command. The format of the Fetch EPROM command is as 
follows: 

Command Key Sequence: [F] [starting Prompt address] [NEXT] 

[ending Prompt address] [NEXT] 

[starting EPROM address] [EXECUTE] 

Function Display: “FP. . ” 

Address Range: O-FFFig (but not to exceed PROM capacity) 

The Fetch EPROM command moves the contents of the EPROM Program Memory of the 
device installed in the Programming Socket to the RAM Program Memory in Prompt-48. 
Before specifying this command, an 8748, 8741 , or 8755 with 475 adapter must be installed 
in the Programming Socket. If no EPROM device or 475 adapter is present and locked, or if 
the device is placed in the socket backwards, upon receipt of the [F] command the display 
will read out an error message. 

Example: Read the contents of an 8748 installed in the Programming Socket into the RAM 
Program Memory in Prompt-48. The key sequence is [F] [0] [NEXT] [3] [F] [F] 
[NEXT] [0] [EXECUTE]. 
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Table 5-7. Command List Summary 


Command Prompts: “ACCESS=0” and 




Command Key(s)/(Description) 

Function Display 

Section 

[GO]; 

“G . 


5-20 

- [NO BREAK] 

“Go. 


5-21 

- [WITH BREAK] 

“Gb. 


5-24 

- [SINGLE STEP] 

“GS. 


5-24 

[EXAMINE/MODIFY]: 

“E . 


5-17 

- [PROGRAM MEMORY] 

“EP. 


5-18 

- [DATA MEMORY] 

“Ed . 


5-17 

- [REGISTER] 

“Er . 


5-15 

[2] (Port 2 Map) 

“P2. 

MM” 

5-16 

[3] (Program PROM — 8741 or 8748) 

“Pr 

8741 

5-53 

[3] (Program PROM — 8755, with adapter) 

“Pr 

8755 

5-53 

[4] (Byte Search): 

“SI . 

. 

5-25 

- [PROGRAM MEMORY] 

“SP. 

. 

5-26 

- [DATA MEMORY] 

“Sd . 


5-27 

- [REGISTER] 

“Sr . 


5-28 

[5] (Word Search): 

“S2 . 

>1 

5-25 

- [PROGRAM MEMORY] 

“SP. 


5-28 

- [DATA MEMORY] 

“Sd . 


5-30 

- [REGISTER] 

“Sr . 


5-31 

[6] (Hexadecimal Arithmetic) 

“HE. 


5-49 

[7] (Program PROM — 8748) 

“Pr 

8748 

5-52 

[8] (Compare PROM) 

“Co . 


5-54 

[9] (Move Memory); 

“n . 


5-32 

- [PROGRAM MEMORY] 

“nP . 


5-33 

- [DATA MEMORY] 

“nd . 


5-34 

[REGISTER] 

“nr . 


5-35 

[A] (Access Mode Select) 

“Ac . 

CC” 

5-14 

[B] (Examine/Modify Breakpoint) 

“br . 


5-23 

[C] (Clear Memory); 

“C . 


5-36 

- [PROGRAM MEMORY] 

“CP. 


5-37 

- [DATA MEMORY] 

: “Cd. 


5-38 

- [REGISTER] 

“Cr . 


5-39 

[D] (Dump Memory); 

“d . 


5-40 

- [PROGRAM MEMORY] 

“dP . 


5-41 

- [DATA MEMORY] 

“dd . 


5-42 

- [REGISTER] 

j “dr . 


5-43 

[E] (Enter into Memory); 

“r 


5-44 

- [PROGRAM MEMORY] 

“rP . 


5-45 

- [DATA MEMORY] 

“rd . 


5-46 

- [REGISTER] 

“rr . 


5-47 

[F] (Fetch PROM) 

“FP 
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CHAPTER 6 
HOW TO USE PROMPT 48 


6-1 . Setting Up A System 

As mentioned in the introductory chapter of this manual, your decision to use the Prompt -48 
as a development system was likely based on the observation that software design and debug 
time is the critical path that stands between where you are now and a completely engineered 
product. The hardware aspects of system design using the MCS-48 family of components, 
though not trivial, are greatly simplified by the forethought and modularization of that 
family. 

In this chapter we will refer to your prototype of the desired end product as the user system. 
This chapter will attempt to guide you in the efficient use of the development tools of the 
Prompt -48, while giving the briefest of coaching in the modem discipline of systems 
engineering. 

6-2. Education 

The first step is to become familiar with what the microcomputer is and what it can do. For 
this, unless you are already familiar with the subject, reference should be made to Chapter 
Three of this manual, ‘ ‘How the INTEL Chip -Computers Work. ’ ’ An extensive documen- 
tation package is included with Prompt-48, and this should also be consulted. In particular, 
you should become familiar with the contents oi MCS-48 Microcomputer User* s Manual 
and the Prompt 48 Reference Cardlet. 

If time is critical in getting started in microprocessors, designers or managers can attend one 
of many INTEL- sponsored 3 -day training courses which give basic instruction in the 
MCS-48 as well as hands-on experience with MCS-48 development systems. 

After general familiarization is complete, either through self-instruction or a training 
course, the next step is to gain a better “feel” for what a microprocessor can do in your own 
applications by writing several exercise programs which perform basic functions. You may 
require such things as I/O routines for various sorts of ports; or delays, counting functions, 
look-up tables, arithmetic functions, and logical operations which can serve as a set of 
building blocks for future applications programs. Several basic programming examples are 
included in the Prompt -48 documentation package, such as the “Stopwatch” program 
described and listed in Appendix C of this manual. The Intel User’ s Library is a source of 
more specific applications routines. 

6-3. Functional Deflnition 

After a thorough grounding in the basics of microcomputing has been achieved, the 
functions of the intended user system should be thoroughly defined and documented. So 
many “correct” methods for this sort of documentation exist that it is impossible to make 
dogmatic prescriptions for all situations. 

A traditional protocol of design- supportive documentation is the flowchart method. This 
familiar device, for which templates and other drafting aids exist, calls for a separate ‘ ‘black 
box’ ’ with summary description within for each distinct “function’ ’ to be performed by the 
computer; also, the proper sequencing and interconnection of functions, including the 
possibility that certain paths may only be remote options, seldom used. 

We will employ a different discipline of program design in this chapter and in Appendix C, 
known as structured programming through Wamier-Orr diagrams. Rather than “graphics- 
oriented” like flowcharts, this documentation is analogous to indented outlines. Examples 
appear in Paragraph 6-6. 
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6-4. Hardware Configuration 

The next step involves the definition of the microcomputer hardware necessary to imple- 
ment the complete user system. In general, any system will include CPU (Central Proces- 
sor), Program Memory and Data Memory, Input/Output, and the appropriate interfaces 
with the outside world. It will already be apparant that the MCS-48 component family 
answers many system-building questions in a straightforward manner. In the first place, the 
8748, if selected as Central Processor, already includes the first one thousand bytes of 
Program Memory , the first 64 bytes of Register (data) Memory, and three 8 -bit I/O ports. 
For those many applications requiring no more resources, the 8748 (or its masked ROM 
equivalent, the 8048) would have only a few hardware needs beyond the chip itself: a power 
supply (which could be a battery), a simple oscillator or clock, a minimal amount of 
interface/support circuitry, and possibly a chassis or other packaging. 

But most user applications will be more involved than this, requiring a detailed hardware 
system design study and the use of other components in the MCS-48 family. Such a design 
study would require the separate consideration of requirements in Input/Output, Memory 
and Throughput. Input/Output and Memory will now be discussed, but Throughput will be 
covered in the subsection which follows, “Code Generation.” 

Input/Output capability must be defined in terms of number of inputs, number of outputs, 
bi-directional lines, latching or non-latching I/O, output drive capability, and input 
impedence. 

In terms of Memory requirements , a separate study is necessary for Register (Data) Memory 
and for Program Memory. The number of words of RAM storage required for intermediate 
results and other data storage must be determined, and a decision made as to whether 
off-chip expansion is needed. (An additional 256 bytes can be directly added, and up to 4K 
bytes indirectly; see Paragraph 6-14 for details.) The type of system will dictate whether 
battery backup is needed to maintain data in RAM during power failure. 

Probably the most difficult parameter to define initially is the amount of Program Memory 
needed to store the final user program. Although previously written exercise programs will 
make this estimate more accurate, a generous amount of “breathing room” should be 
allowed in program memory until coding is complete and the exact requirements are known. 
The Prompt -48 allows for Ik byte (one thousand bytes) of RAM memory for program 
development. If more proves to be necessary, the user can configure it externally to Prompt 
with the Bus Connector (Jl) and flat cable. (MCS-48 has an upward address limit of 4k in 
Program Memory.) 

The problem of “trade-offs” of hardware versus software is familiar to every experienced 
system designer. For example, many special functions such as serial data communications 
(TTY or RS-232) or keyboard/display interfaces may be implemented in software (pro- 
grams); however, in cases where these functions place a severe load on the processor in 
terms of time or Program Memory, special peripheral interface circuits such as the 8251 , 
Universal Synchronous or Asynchronous Receiver/Transmitter (USART) or 8279 
Keyboard/Display interface may be used. 

We are only sketching the essentials of hardware system development in this section. For 
full details, see Paragraph 6-14. 


6-5. Code Generation 

The writing of the final program code for the application can begin once the system function 
and hardware have been defined and can be generated in parallel with the detailed hardware 
design (PC card layout, power supply, etc.) Often the final hardware definition is not 
possible, however, until some or all of the coding is complete; the memory requirements, 
both for Program Memory and Data Memory, may be unpredictable. Also, it may not be 
possible to predict, in certain time-critical real-time applications , whether the processor will 
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have sufficient throughput. “Benchmark” programs, which are typically only the most 
critical sequences in a complete applications program, are often written in completely coded 
form for the purpose of more exactly predicting memory and throughput requirements. 

Throughput is defined loosely as the “amount of computing’ ’ that a system can accomplish 
in a given time interval. Although a fast processor like the MCS-48 has throughput 
“overkill” for most applications, it is easy to conceive that a sufficiently challenging 
real-time application would overtax its processing power. For example, in some industrial 
control application , a feedback loop between ‘ ‘ sensing’ ’ and ‘ ‘ correcting’ ’ might need to be 
repeatedly established very quickly, say within 1/lOOth of a second. Such afinal, dedicated 
applications program may be able, in addition to any general “housekeeping” or record- 
keeping duties, to periodically read the current outside- world data appearing at an input 
port; to perform data analysis calculations; to compute a feedback or correction factor; and 
to write this to an output port — all within perhaps 1/lOOth of a second. 

If benchmark programs are carefully-selected and completely coded, it is possible to make 
literal and accurate calculations for the time required to execute them. One simply counts 
the number of bytes in the benchmark program (object code) and multiplies by the 
instruction cycle time of the MCS-48. Assuming a clock frequency of 3 MHz (3 million 
cycles per second), the basic instruction cycle for the fetching/executing of a program byte 
would be 5.0 microseconds long. (Reference XhQ MCS-48 Microcomputer User's Manual.) 
Note that most MCS-48 instructions generate only one byte of object code, but that many 
have operands requiring a second byte. 

The whole process of applications software development, from program design to final 
coding, is described in Paragraph 6-6. 


6-6. Programming Techniques 

The first part of this section is aimed primarily at beginning or intermediate assembly 
language programmers. While it is not sufficient as a general introduction to assembly 
language programming, it is intended to present concepts allowing efficient software 
development in the MCS-48 environment. The advanced programmer may wish to spend 
some time briefly examining the subsections on Program Design and Program Test and 
Debugging for interest’s sake. 

The subsections: 

Assembling IMP and CALL Instructions, 

Program Memory Paging, and 
Prompt -48 Considerations, 

are of general interest as they discuss aspects pertaining specifically to the MCS-48 family 
or Prompt 48. 

The MCS-48 Assembly Language Programming Manual should be consulted as a detailed 
reference for all MCS-48 CPU software. 


6-7. Program Design 

The first step in the design of any system, hardware or software, is to define the problem. 
Only when the exact function of the application is determined can the resources necessary to 
execute that function be determined. 

A common phrase in programming these days is “top-down” program design. By this we 
mean that the designer divides the problem into smaller separate sections to be solved 
separately. The words “top-down” describe the hierarchial or pyramid- like way in which 
this division is made. As an example, let’s say that we are to design a program which will 
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allow a particular MCS-48 system to function as a stopwatch; perhaps we will design it to 
run on Prompt 48 itself. When we say “stopwatch,” the precise instructions needed aren’t 
immediately obvious. The problem must be divided into simpler sub-problems. One 
possible division might be into subsections called: Display Functions, Timer Control 
Functions, Data Functions, User Input/Output Functions, and so forth. These subsections of 
the program are then themselves divided and subdivided until the problem is reduced to a 
number of vastly simpler problems, such as adding 1 to the contents of a given memory 
location. The final set of simple problems is then solved one at a time, and called the 
program modules. 

Figure 6-1 shows a possible partial breakdown of the stopwatch problem. While the figure 
shows the organizational structure of the program, it does not indicate how the modules 
communicate with one another. 

The communication between modules is the second major phase of program design, called 
designing the modular interfaces, which are simply the ways in which modules pass control 
and data back and forth. For example, in the stopwatch the User Control Functions 
(Commands) module must give control to one of its submodules, whose task is to read the 
keyboard for user commands. The Read Keyboard For Command submodule would 
examine keys and return control to the calling module. It would also pass data back to the 
calling module indicating which key, if any, was pressed. The simpler these modular 
interfaces are kept the easier it is to assemble all modules into a working program. For this 
reason the modular breakdown process should attempt to separate the problem into sub- 
problems which depend as little as possible on each other for data. 


User 

Control .. 

Functions 

(Commands) 


Start Stopwatch 
Stop Stopwatch 

Freeze Display at Current Time 
Free (unfreeze) Dispiay 
Set Time to 0 


Dispiay 

Functions 


Stopwatch 


Clear LED Display 
Enable LED Refresh 
Display Minutes 
Dispiay Seconds 
Dispiay Hundredths 


Timer 

Control 

Functions 


Data 

Functions 


Reset Timer 
Start Timer Running 
Stop Timer Running 
Check Timer Status 

Set Time to 00:00.00 
Add 1 to Time 

Read Keyboard for Command 


Figure 6-1. Stopwatch Program Structure 
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When a given task must be performed the same way in two or more modules, it can be made 
into a subroutine. A good example of a subroutine is a multiplication routine. The 
multiplication routine receives control, and the two numbers to be multipled, from the 
calling routine, multiplies the two numbers together, and returns control and the product to 
the calling routine. Since subroutines are called from a number of different areas in the 
program, the address of the caller must be saved in order for control and data to pass back to 
the calling module. This is accomplished very simply in the MCS-48 Chip-Computers and 
is described in Paragraph 3-9. 

The concept of executive modules is also useful. Briefly, an executive module is any 
module which controls other modules as subroutines. This idea can be applied at any level in 
the structure of the program, just as the idea of modules itself. In the stopwatch structure, the 
User Control Functions module is executive to the other three modules on its level. 


6-8. Hand Assembly 

When each program module and modular interface has been specified, the individual 
modules must be translated into a form the computer can deal with. The first step of this 
translation is to write the program in assembly language according to the MCS-48 Assembly 
Language Manual. If an ISIS-II or other development system is available to then assemble 
the assembly language program into machine language, hand assembly need not be used; 
otherwise, the hexadecimal machine code contents of Program Memory must be determined 
manually. 

Let’s look at a simple example. Consider a single-module program which is to count. That 
is, it will repeatedly add 1 to a specified memory location. The task of the program (module) 
might look something like this: 


1. Replace the variable COUNT with COUNT+1. 

2. Repeat step 1. 


The next step is to assign the location of the data called COUNT. Let’s put it in Working 
Register 0. Now write the instructions: 


START: MOV A,#l 
ADD A,R0 
MOV R0,A 
JMP START 


;Put 1 in the Accumulator 
;Add 1 to RO (COUNT) 
;Replace RO with RO+1 
;Repeat forever. 


The mnemonic instructions with comments are collectively called the program source code. 
The hexadecimal contents of Program Memory which the source code stands for are called 
the program object code. The essence of hand assembly is the translation from source code 
to object code. 

In our example we must now do just that: assemble the program. 


First, a starting address must be chosen; say Program Memory location 0. Write the address 
of each instruction at the extreme left of your program sheet: 


Addr 


Label Ins Opnd 


Comment 


000 


START: MOV A,#l 


;Put 1 in the Accumulator 
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Then go down the instructions one at a time, assigning hexadecimal values to the Program 
Memory address in the left column: 


Addr 

Data 

Label 

Ins Opnd 

Comment 

001 

2301 

START: 

MOV A,#l 

;Put 1 in the Accumulator 

002 

68 


ADD A,R0 

;Add 1 to RO (COUNT) 

003 

A8 


MOV R0,A 

;Replace RO with RO+1 

004 

0400 


IMP START 

;Repeat forever. 


The hexadecimal values can be looked up in the Prompt -48 Reference Cardlet (“by 
mnemonic” section), the MCS -48 Microcomputer User's Manuaf or the MCS -48 Assem- 
bly Language Programming Manual. 


6-9. Program Test and Debugging 

When each of the program modules and their modular interfaces have been identified and 
written into an assembly language program, some effort should be devoted to determining 
whether or not the program works as intended. This effort is called program testing. 
Removing the errors uncovered by program testing is called debugging. 

Large programs are frequently far too complex to exhaustively test as a whole. One answer 
to this problem is to test as thoroughly as possible each module and modular interface 
individually. If this is done carefully, the programmer is almost certain to have a correctly 
working program when the modules are assembled, unless there are serious flaws in the 
overall program design structure. The bugs that do (almost inevitably) crop up can usually 
be identified as originating in a particular module and/or modular interface, and are easily 
fixed. 

In order to evaluate the performance of an individual module, its communication process 
with other modules must be simulated. For example, if a multiplication routine is to be 
tested, the input data (the numbers to be multiplied) must be somehow provided, and the 
output data (product) must be available for verification. Thus, the stand-alone routine to be 
verified must be provided with an “environment”: that is, it must be surrounded with 
sufficient other assembly-language instructions so that it can be run in the computer with 
simulated values . Such a test program would be called a ‘ ‘ dummy routine, ’ ’ and the practice 
of pre- verifying individual modules before the program is run as a whole is often referred to 
as “echo checking.” If the module is found to be faulty, the resources of the development 
system must be called on to trace its internal operation. 

The basic facilities for testing modules and modular interfaces in Prompt-48 are the 
Go/With Break, Go/Single Step, and Examine/Modify commands. 

Breakpoints allow the user to stop program execution at pre-planned points in order to 
supply input data, examine output data, check the status of various registers, and so forth. 
The placement of breakpoints and use of the Go/With Break command are discussed in 
Paragraph 5-20. 

The Go/Single Step command allows the user to execute a routine instruction -by - 
instruction, verifying the routine’s operation at each step. The use of this command is 
described in Paragraph 5-20. 

The Examine/Modify commands are the means by which all this verification takes place. 
The MCS -48 registers and Data Memory are accessible through these commands, as shown 
in Paragraph 5-17. 
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6-10. Program Memory Paging 

In MCS-48 Chip -Computers, Program Memory is divided into from 4 to 16 256 -byte 
pages. There are only two ways for program execution to cross page boundaries: the use of 
the IMP or CALL instructions. The address of the next instruction to be executed is kept in 
the Program Counter. After most instructions, only the lower eight bits are modified to form 
the next address (2® = 256). With the JMP and CALL instructions, however, an additional 
three bits are included as part of the instruction. The twelfth bit of the Program Counter (BS) 
is also replaced by the DBF bit with the execution of these instructions. The JMP and CALL 
instructions are therefore the only instructions which can transfer control to anywhere in the 
2^^ = 4096 bytes of Program Memory. 

The DBF bit controls whether a JMP or CALL instruction passes control to a destination 
above or below the 2^ ^ = 2048 byte Program Memory boundary. This is accomplished by 
replacing bit 1 1 (the twelfth bit) of the Program Counter, BS , with DBF on a JMP or a CALL 
instruction. DBF is controlled with the SEL MBO and SEL MBl instructions. SEL MBO 
replaces DBF with 0, and subsequent JMP or CALL instructions will have destination 
address of O-TFFig. SEL MBl replaces DBF with 1, and JMP’s and CALL’S will have 
destinations of SOOig— FFFie. 


6-11. Assembling JMP and CALL Instructions 

With the JMP and CALL instructions, three bits of the destination address (next Program 
Counter contents) are included in the hexadecimal object code for the particular instruction 
involved. These bits are Program Counter bits 10, 9, and 8. They specify any 256 byte page 
of Program memory in either of two Program Memory banks, OOO-TFFie or 800i6— FFFig. 
To determine which page of the given memory bank the destination lies in, take the full 
address (OOO-FFFie) and subtract 800i6 from any address which is 800i6 or greater. The 
resultant page number indicates the proper JMP or CALL instruction’s object code. 

The precise manner in which the JMP and CALL instructions operate is discussed in 
Paragraphs 3-8 and 3-9, and the MCS-48 Microcomputer User's Manual. 


6-12. Care and Feeding of EPROMS 

At a certain point in program development you will make the decision that the process is 
complete: that is , you will have verified that the program works as designed. Hopefully you 
will already have attempted a certain number of dry runs under ‘ ‘ dummy ’ ’ parameters , in an 
attempt to force the program into some sort of fluke under extreme conditions; perhaps it 
will only be a random and arbitrary selection of parameters. Now it is time to commit the 
proven program to non-volatile EPROM, either the Ik resident on the 8748 processor, or 
possibly the 2k 8755 EPROM Program Memory and VO Expander device. 

To do this, carefully insert the chip in the Programming socket with the marked pin on the 
chip next to the numeral “ 1 ” on the Prompt’ s panel insuring proper orientation. There are 
numerous cautions to observe while doing so. In the first place, never insert a processor into 
the Programming socket unless a second processor (such as the 8035 provided with your 
Prompt) is properly locked in the Execution socket. Secondly, the chips are fragile! 
Dropping, twisting, or uneven pressure may break them. Also, avoid putting any pressure 
on the quartz window area of the processor. Finally, as MOS devices the EPROMs are 
subject to damage by static electricity contacting the pins. Never place the pins near any 
metallic surface except the Prompt socket itself; and even then, discharge any residual 
charges by touching your hand to the Prompt chassis before inserting the chip. At all other 
times, keep the chip safe in its protective foam cushion. 

The final step in EPROM programming is to execute one of the instructions for this purpose 
detailed in Paragraph 5-50. 
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If for any reason it is desired to erase a programmed EPROM to allow for reprogramming, it 
is only necessary to expose it to light with wavelengths of light shorter than approximately 
4000 Angstroms (utoaviolet). Sunlight and certain fluorescent lamps have wavelengths in 
the 3000 A- 4000 A range. If the 8748 is to be exposed to sunlight or room fluorescent 
lighting for extended periods, then opaque labels should be placed over the window, to 
prevent unintentional erasure. 

The recommended erasure procedure is exposure to shortwave ultraviolet light which has a 
wavelength of 2537 A. The integrated dose (UV intensity multiplied by exposure time) for 
erasure should be a minimum of 15 W-sec/cm. The erasure time with this dosage is 
approximately 15 to 20 minutes using an ultraviolet lamp with a 12,000 /xW/em^ power 
rating. The 8748 should be placed within one inch from the lamp tube during exposure. 
Some lamps have a filter on their tube and this filter should be removed before erasure. 


6-13. Prompt 48 Considerations 

A few of the full capabilities of the MCS-48 Chip -Computer are restricted in the Prompt 
environment. This is due to design tradeoffs necessary to provide the full versatility of 
Prompt’s features and functions. It is possible to work around these restrictions, which 
disappear once the development cycle is complete and the user system stands and runs 
alone, provided that you are aware of them in advance. 

Monitor Reentry Uses Stack: When the MON INT key is pressed, the monitor program 
interrupts the user program, using one stack entry. If the user has calculated his stack needs 
only for his own subroutines and interrupts, and has stored other data on the next available 
stack location , that data will be ‘ ‘ zapped’ ’ (overwritten) by the user program return address . 

Unsupported Instructions: ANL BUS, A and ORL BUS, A will not work except in Access 
Mode 3 and then only with the GO/NO BREAK command. OUTL BUS , A can only be used 
in Access Modes 0 and 3 . 

Monitor Reentry Code: The upper 16 bytes of the lower Ik block of Program Memory 
(addresses 3F0i6 through 3FFi6) must be reserved for the Prompt 48 Monitor reentry code. 
This code is automatically placed in Program Memory by the [7] Program EPROM 
command. (See Paragraph 5-50.) These bytes must also be reserved when using the RAM 
Program Memory inside Prompt 48. 

Access Code, P2 Map. LSN P2 Relationship: Care must be taken to insure that these three 
things are in agreement, as described in Paragraph 5-13, 5-15, and 6-14. 

Timer Routines: The Timer Interrupt is disabled when using the GO/WITH BREAK and 
GO/SINGLE STEP commands. To debug timer routines, insert JTF (Jump if Timer 
Flag = 1) in the program loop. 


6-14. Hardware Considerations 

In expanding either Program or Data Memory, the first step is to define how the expanded 
memory is to be partitioned, i.e.. Program vs. Data. In your final MCS-48 design, 
processor control signals will distinguish Program Memory accesses from Data memory 
accesses: PSEN/ signals instruction fetches from Program Memory, and RD/ and WR/ 
signal accesses to Data Memory. Thus your final design will be a “Aiken” machine, with 
separate Program and Data Memory (see Chapter 3). 

However, during debugging you may find a “von Neumann” machine to be useful, 
particularly if you are expanding Program Memory. While checking out software you need 
to easily load and modify all of Program Memory , 1 k or more . Expansion Program and Data 
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Memory may be joined into a single, all -RAM store — though Program and Data addresses 
may not overlap. In hardware, you must now AND the PSEN/ and RD/ signals to form what 
we’ll call EXRD/ (expansion read). This signal selects the expansion RAM whenever an 
instruction is fetched from expansion Program Memory or when an expansion Data 
Memory location is read. 

A design for such “von Neumann’ ’ expansion memory is shown in figure 6-2. Table 6- 1 is a 
list of the pin functions on the I/O Ports and Bus Connector ( J I ) on the front panel of Prompt , 
necessary for the proper configuration of ribbon cable between the user system and Prompt. 
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Table 6-1. Pin List for I/O Ports and Bus Connector 


Signal Name 

Pin No. 

Buffer Characteristic 

BUS (0) 

17 


(1) 

21 


(2) 

25 


(3) 

29 


(4) 

31 

3-STATE BIDIRECTIONAL 

(5) 

27 


(6) 

23 


(7) 

19 


PORT1 (0) 

18 


(1) 

20 


(2) 

22 


(3) 

24 

8748 PSEUDO BIDIRECTIONAL 

(4) 

26 

CHIP (NO BUFFER) 

(5) 

28 


(6) 

30 


(7) 

32 


PORT 2 (0) 

7 




3-STATE MAPPED BIDIRECTIONAL 

(1) 

5 

with 100 H IN SERIES 

(2) 

3 


(3) 

1 


PORT 2 (4) 

4 


(5) 

6 

8748 PSEUDO BIDIRECTIONAL 

(6) 

8 

CHIP (NO BUFFER) 

(7) 

10 


+ALE 

13 

TTL OUTPUT (10 

+T0 

14 

CHIP BIDIRECTIONAL (CLOCK), 2.2K Pullup 

+T1 

12 

CHIP INPUT, 2.2K input 

-INT 

49 

1 TTL LOAD (MON. GATED) 

-PSEN 

15 


-RD 

9 

TTL OUTPUT (1 0 LS LOADS) 

-WR 

11 


-PO WRITE 

33 

TTL OUTPUT (5 LS LOADS) 

-PROG 

2 

CHIP OUTPUT (NO BUFFER) 

-RESET 

16 

CHIP INPUT/OUTPUT (SYS RESET OVERRIDES), 2.2K pullup 

GND 

45, 46 

Ground 


47, 48 



6-15. Data Memory Considerations 

Prompt 48 has 256 internal Data Memory locations, not including the 64 on-chip Register 
Memory locations, accessible to you as ‘ ‘External Data Memory,” via the MO VX instruc- 
tions . These 256 bytes of external data memory — inside the Prompt box — will be accessed 
by MOVX instructions whenever LSN P2 is less than or equal to 3. That is, external data 
locations 0 will be accessed by addresses 0, lOOi^, 200i6, or 300. Accesses to 400 and 
beyond will be outside the Prompt box (except in Access = 2,5). 

For a fuller treatment of the vital P2 subject, see the appropriate subsection below. 


6-16. Using and Expanding Prompt 48 I/O Ports 

All I/O pins of the EXECUTION SOCKET processor are accessible via the VO PORTS 
AND BUS CONNECTOR (see Table 5-1). Some lines are buffered inside the Prompt, and 
therefore differ somewhat from a standalone MCS-48 device. 

The connector pins designated port 1 are not buffered; they are connected directly to the 
EXECUTION SOCKET computer. 
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The connector pins designated port 24 through 27 are not buffered; they are connected 
directly to the EXECUTION SOCKET computer. However, the pins designated port 20 
through 23 (the LSN P2) are buffered. Ordinarily the P2 MAP function [2] specifies 
whether the lines of port 2 are to be used as input or output. The map enables appropriate 
port 2 buffers, and allows you to examine/modify port 2 (“register 47”) from the Prompt 
panel. The default for P2 MAP is that all lines be output. Important: Do not confuse the P2 
MAP with the port itself (register 47). They are entirely different. 

If LSN P2 is to be used as input, you must map it accordingly, and execute from on-chip 
program memory only ( 1 K or less), ACCESS = 3 or 5 . The MSN P2 can be input whenever 
it is so mapped. 

The Prompt does not usually allow any P20-P23 pin to be both input and output. The one 
exception is using an 8243 I/O expander (and ACCESS = 1,4). Then Prompt ignores P2 
MAP and automatically switches the LSN P2 buffers between input and output, as signalled 
by the PROG pin. 

The connector pins designated BUS 0 through 7 (also known as port 00 through 07) are 
buffered. In access codes 0 and 3 will latch. These lines will be latched outputs. No inputs 
are allowed, and memory may not be expanded outside Prompt box. The MCS 48 processor 
can, however, execute monitor programs or user programs from writable program memory, 
and these bus transactions do not appear on the latched PORT 0. Only the OUTL PO 
instruction or any instruction generating writes (WR) will alter the latched BUS (PO) 
contents; ANL PO and ORL PO instructions have no effect. 

If you are using BUS for input, for strobed output or for expansion memory (and memory- 
mapped I/O) then you will select access 1, 2, 4 or 5. Prompt requires that LSN P2 >3 for 
access outside the Prompt box, including input, strobed output expansion memory and 
memory-mapped I/O. 

Prompt provides a signal called -POWR which goes low whenever Prompt’s port 0 latch 
buffers are driving out of the box. You may use this signal to disable any of your user system 
bus drivers which might be driving into the Prompt box. 


6-17. P2 Map, LSN of P2, Access Code Considerations 

P2, or Port 2, is one of the MCS-48 processor’s three 8-bit parallel I/O ports. It acquires 
special significance because it is used to output the Most Significant 4 address bits of 
transactions with both Program Memory and Data Memory (the 8 Least Significant bits of 
the 12-bit address are provided by the BUS port). Only the Least Significant Nibble of P2 is 
required for this purpose; thus the numerous references in this manual to LSN of P2 
considerations. 

The P2 Map is given by the user through a panel command (see Paragraph 5-15) to establish 
the signal direction on a pin by pin basis within Port 2. (The default condition is “output.”) 
The Most Significant Nibble ofP2 may be freely mapped as “input” or“output” according 
to the user’s needs. But because of the Prompt 48 environment, the LSN P2 Map could 
compete with Prompt’ s drivers under certain Access Modes. This requires explanation on a 
mode-by-mode basis: 


6-18. Modes 0, 2, or 5: Map LSN as Output. LSN pins are used in these modes by the 
Monitor to select various internal memories of the Prompt 48 and therefore must not be 
affected by input devices. Referring to Figure 6-3, we can see the datapath is P2, H, J, K. If 
LSN is mapped input, data path Jl, A, D, G, H could foul things up. 
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6-19. Mode 1 or 4: Mapping is Don’t Care. LSN is used by the user to select various 
external memories, I/O chips, and/or 8243 Port Expander chips he may have connected to 
J1 . Being select lines, the LSN function will always be output except if using an 8243 Port 
Expander. In Figure 6-3 the path is H, G, B, E, J1 , The LSN mapping mechanism is actually 
bypassed in these modes and is therefore immaterial. If it is mapped as output, the contents 
are saved by the monitor during debug. If using an 8243, on a MOVD A, Pn command, the 
path switches to Jl, F, B, G, H. 


6-20. Mode 3: Mapping May Be Input or Output as the User Requires. In this mode 
we are running a program less than Ik long which resides on the processor chip. With Input 
mapping the path is Jl , A, D, G and H. With Output mapping the path is P2, H, J, C, A, Jl . 
You might notice that if the Monitor takes control (due either to single-step, with-break, or 
Monitor interrupt pressed) the last data on the 4-bit latch is held and the P2 Map is 
temporarily switched to Output. Again, this is to prevent possible input lines from affecting 
the internal memory select lines. 



Figure 6-3. PROMPT 48 Port 2 Bus Structure 
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6-21. LSN P2 Considerations. Prompt 48 is designed to automatically select the correct 
program memory: addresses 0 to 3FF (IK-l) are inside the box, either on-chip EPROM or 
its writable substitute. Addresses 400 to FFF (IK or greater) are to expansion memory, 
which you provide outside the box. The correct memory is automatically selected by using 
the LSN P2 as an “inside/outside resource switch”. 

If LSN P2 (< IK), then all accesses are to resources inside the Prompt box. If LSN P2 
>3 IK), all accesses are to resources outside the Prompt box. 


6-22. Using the Serial I/O Port 

Prompt 48 is shipped from the factory with its default options strapped for use with the 
Prompt-SPP Option, but may alternatively be strapped for 20- mA current loop Teletype- 
writer terminal or for any RS232c-compatible terminal. 

The Serial I/O Interface communicates with an external I/O device via a 26-pin double- sided 
PC edge connector (J2), 0. 1 inch centers. An external device can be connected to J2 using a 
3M 3462-0001 flat cable connector or one of the following soldered connectors: TI 
H312113 or AMP 1-583715-1. Table 6-2 provides a pin list for connector J2. 

Expansion program memory is automatically selected by the most significant nibble of PC, 
which is strobed through LSN P2 during program memory fetch (PSEN/). However, 
expansion data memory (or memory-mapped I/O) which is outside the Prompt box will be 
selected only if LSN P2 >3. That is, if either P22 or P23 = 1 . 

For example, to access data memory outside the Prompt box (MO VX) you may need to 
insert in your program LSN P2 >3. (If LSN P2 =^3, MOVX will access the external data 
memory inside the Prompt box.) 

When your MCS 48 system finally stands alone, without Prompt, the LSN P2 requirement is 
obviated. 

From the Prompt 48 panel you can [EXAMINE/MODIFY] [PROGRAM MEMORY] in the 
range 400-FFF. Prompt’s monitor will generate reads (RD) and writes (WR) to whatever 
expansion devices — program memory, data memory, or memory-mapped I/O — are 
addressed by the 12 bits LSN P2 BUS. The [EXAMINE/MODIFY] [DATA/MEMORY] 
button only accesses the 256 bytes external data memory inside the Prompt box. 


Table 6-2. Connector J2 Pin Connections 


Pin 


Pin 


1 

CHASSIS GND 

2 

+5V (if 31-32 strapped) 

3 

TRANSMITTED DATA 

4 


5 

RECEIVED DATA 

6 

TTY RD CONTROL 

7 

REQ TO SEND 

8 


9 

CLEAR TO SEND 

10 


11 

DATA SET READY 

12 


13 

GND 

14 

Tx CLK/DATA TERMINAL RDY 

15 

DATA CARRIER RETURN 

16 

TTY RD CONTROL RETURN 

17 


18 


19 


20 


21 


22 

RECEIVE CLK/TTY Rx 

23 

TTY Rx RETURN 

24 

TTY Tx RETURN 

25 

TTY Tx 

26 

GND 
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Table 6-3. Serial I/O Port Strapping Options 


Prompt-SPP 

TTY 

RS232 

1-2 (J2-1 = GND) 

1-2 

1-2 

3-4 (J2-^ = RD CNTL) 

3-4 

4-5 

6-7 (J2-14 = DSR) 

6-7 

6-7 

9-12 (RTS = CTS) 

9-12 

9-12 

10-11 (J2-7 = Always 

10-11 

10-11 

CTS High 



14-15 (TXC = RXC) 

14-15 

14-15 

17-18 (J2-23/32) 

17-18 

16-17 

19-20 (2400 BAUD) 

19-20 

See Table 6-4 

21-27 (2400 BAUD) 

21-25 

See Table 6-4 

31-32 (J2-2 = +5V) 

Disconnect 

Disconnect 31-32 

31-32 


All others 

Disconnected 


CAUTION: Unrelated to the serial interface may be a jumper from 29-30. This must 

remain untouched at all times. 




Table 6-4. Band-Rate Selection 


Baud Rate 

Strapping Connections 

4800 

2400 

1200 

600 

300 

150 

75 

110 (TELETYPE) 

21-26 (1 9 & 20 DON’T MATTER) 

21-27 (19 & 20 DON’T MATTER) 

21-28 (1 9 & 20 DON’T MATTER) 

21-22 (DISCONNECT 19 & 20) 

21-23 (DISCONNECT 19 & 20) 

21-24 (DISCONNECT 19 & 20) 

21-25 (DISCONNECT 19 & 20) 

21-25 AND 19-20 


6-23. Interfacing to a Teletypewriter 

The teletypewriter must receive the following internal modifications and external connec- 
tions, for use with the Prompt 48. 


6-24. Internal Modifications. Complete the following internal modifications. 

a. The current source resistor value must be changed to 1450(1. This is accomplished by 
moving a single wire (see Figure 6-8). 

b. A full duplex hook-up must be created internally. This is accomplished by moving two 
wires on a terminal strip (see Figures 6-6 and 6-10). 

c. The receiver current level must be changed from 60 mA to 20 mA. This is accomplished 
by moving a single wire (see Figures 6-7 and 6-10). 

d. A relay circuit must be introduced into the paper tape reader drive circuit. The circuit 
consists of a relay, resistor, a diode, a thyractor and a suitable mounting fixture. This 
change requires the assembly of a small ‘ ‘vector” board with the relay circuit holes in the 
base plate (see Figure 6-4). The relay circuit may then be added without alteration of the 
existing circuit (see Figures 6-4 and 6-6). That is, wire “A” (Figure 6-10), to be 
connected to the brown wire near its connector plug. The “line” and ‘ ‘local’ ’ wires must 
then be connected to the mode switch (see Figures 6-6 and 6-10). 


Prompt 48 
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MOUN1 SCRE 


8BOWN WIRE 


TEBMIl^AL m 


6-25. External Connections. Complete the following external modifications. 

a. A two-wire receive loop must be created. This is accomplished by the connection of two 
wires between the teletypewriter and the Prompt 48 in accordance with Figure 6-10. 

b. A two- wire send loop similar to the receive loop must be created. 

c . A two- wire tape reader loop connecting the reader control relay to the Prompt 48 must be 
created. 


Figure 6-7. Terminal Block 


Figure 6-5. Distributor Trip Magnet 
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NOTES: UNLESS OTHERWISE SPECIFIED 




CUSTOMER EXTERNAL CONNECTIONS 


ITEMS WITHIN DASHED LINES REPRESENT CUSTOMER 
REQUIRED MODIFICATIONS 


IM IS INTERNAL MODIFICATION 
EC IS EXTERNAL CONNECTION 


TERMINAL BLOCK 151411 



BLU 


R 

rt n n n 



CURRENT SOURCE RESISTOR 



115 AC 
COMMON 


'LOCAL' 


Figure 6-10. Prompt/TTY Wiring Diagram 
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6-26. Questions Most Often Asked 

6-27. Use of INS A, BUS. 

At the chip level, the MCS-48 BUS port was designed to work in one of the following 
configurations, not in a combination of these modes. 


CONFIGURATION 

IN/OUT 

COMMAND 

1) Bi-Directional 

both 

MOVX 

2) Uni-Directional 

out 

OUTL 

3) Uni-Directional 

in 

INS 


In all 3 configurations, command RD/ and WR/ is produced but is not generally used on the 
INS and OUTL. 

PROMPT 48 supports the first and second configurations completely: bi-directional, using 
access mode 1 or 4 and uni- directional output using access mode 0 or 3. 

The INS command can be used by doing the following: 

a. Use access mode 1 or 4 

b. Set (Drive High) port 2 line 2 or 3 (explained in #8 below) 

c. Strobe the data onto the bus with the RD line (Figure 6-11). 


1 

I 





Figure 6-11. Strobed Data Input 
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Figure 6-12 shows the reason for the above steps. Access mode 1 or 4 enables a bi- 
directional driver and tri- states a latch that holds the data on an OUTL Bus, A command. 
Setting P22 or P23 deselects internal PROMPT 48 memories. Data must be strobed onto the 
bus or else the inputs would fight the 8216 drivers which are driving out when RD is 
inactive. 


6-28. RAM And I/O Selection 

On MCS-48 systems, the MOVX command is used for data and I/O transfers with RO or R1 
as a pointer. The addressing capability is then limited to 1 page (256). This is expanded to 
4K by using P20-23, decoded to 16 page selects. Internally the PROMPT 48 requires the 
first IK addresses, i.e., P22 and 23 low. There are 2 consequences of this: 

a. To access the 256 byte user RAM that’s inside the PROMPT 48, the user program must 
output O’s to P22 and 23. (drive low). P20 and P21 are ‘don’t care’. 

b. To select data and I/O that has been bussed to J1 , either P22 or P23 has to be driven high 
(logic 1). This deselects any internal memory. 

Summarizing the above: 


Internal 
Prompt 48 — 

External 
Selection 
(Model or 4) 


A11 A10 A9 A8 A7 A6 AS A4 A3 A2 A1 AO 

P23 P22 P21 P20 (RO) 

^ (R1) 


0 0 X X 

I O 1 X X 

1 0 X X 

1 1 X X 




PATH CLOSED IF 
P22 AND P23 ARE LOW 


Figure 6-12. Data Path Within PROMPT 48 Using INS A, BUS 
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6-29. TTY and CRT Peripherals Are Used Only For Dumping Or 
Reading Paper Tape 

The keyboard input is not a substitute for the keypad on the PROMPT 48. 


6-30. Speed Degradation Occurs When ^‘GO WITH BREAKPOINTS’’. 

This is due basically because the operation is a replica of single- stepping. This means that 
after every instruction the monitor re-takes control, saves the processor state, checks the PC 
against the eight breakpoints, then restores the processor state and goes back to the User 
mode. — If your program has timing loops in it, the speed of execution will be substantially 
lengthened. 


6-31. When Using PROMPT 48 System Calls, Do Not ‘^GO WITH SGL. 
STEP” Or ^‘GO WITH BREAKPOINT” 

The monitor is like a lot of us; it does not handle self-examination very well! 



Do not try to read the program from an 8048 through the PROMPT Program- 
ming Socket. It is meant for EPROMs only! 



APPENDIX A 
A FAMILIARIZATION EXERCISE 


Voltage Selection 

Check the voltage selection switch visible on the PROMPT rear chassis . Ensure it is set to 
your local mains (line) voltage; if not, open the PROMPT box and remove the switch, 
locking plate, set to proper voltage, and reinstall. If you change the switch setting you 
probably should change the fuse. Plug the unit in and turn power on (switch is on rear 
chassis). 


Handling The Processor 

Carefully remove either processor (8748 or 8035) from the conductive foam. The proces- 
sors are mechanically andelectrically fragile, and will shear through the chip and package if 
dropped. Do not apply uneven pressure to the processor — for example, pushing on the lid or 
even on both ends of the package can destroy your processors. 


Insert In Execution Socket 

Pull EXECUTION SOCKET locking arm up towards you. Insert either processor in 
EXECUTION SOCKET, and lock in place by pushing locking arm flush with panel. 


Reset The System 

Press [SYS RST] to reset system. ACCESS = 0 should appear on display. If not, try 
repeating the above steps with the other processor, and notify your Intel service center or 
representative of the problem. 


INTEL SERVICE HOT LINES: 


From locations within California call toll free — 
(800) 672-3507 


From all other U.S. locations call toll free — 
(800) 538-8014 
TWX: 910-338-0026 
TELEX: 34-6372 


From Alaska, Canada or Hawaii call — 
(408) 987-6218 


From Europe call — 

(322) 72-3565 

TELEX: 846-24695 
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There are six access codes , numbered 0 to 5 . Whenever you power up or reset the PROMPT 
system, ACCESS will be set to 0. We will explain how to change ACCESS codes and why 
they are useful momentarily. 

Your PROMPT 48 system is fundamentally different from all other computers: This is the 
first time the processor has been outside the box. You can safely remove the processor(s) 
from the panel sockets at any time, provided a processor is properly inserted in the 
EXECUTION SOCKET whenever you insert or remove a processor from the PRO- 
GRAMMING SOCKET. 

Always insert the EXECUTION SOCKET processor first, and remove the PROGRAM- 
MING SOCKET processor first. 

The EXECUTION SOCKET processor is always executing either the monitor or your (user) 
programs. When ACCESS = 0 or the prompting hyphen character appears, then the 
monitor is ready to accept COMMANDS or FUNCTIONS. 

Let us first exercise the monitor COMMANDS. Notice that the command buttons have been 
color-coded white and blue. Throughout this exercise each bracket pair [ ] is a button to be 
pressed. 

Mnemonics enclosed in braces, e.g., {SMA} or {DIR} are parameters, usually self- 
explanatory, such as SMA Starting Memory Address, or DIR, Direction. You have to push 
two or three hex buttons for each parameter. 


Examining and Modifying Registers 


Press [EXAMINE/MODIFY] [REGISTER], 

Now you may enter any number (address) of any register you wish to examine and/or 
modify. 

Press [0] for register 0. 

Now press NEXT [,] — the comma button — to “open up” register location 0. The contents 
(random) are displayed. 

Now notice you can “roll in” any data that you want in that open register. Press [0]. 
Suppose you want 1. Press [1]. Suppose you want 22. Press [2] [2]. 

The monitor allows you to roll data into any location as long as it is open. A location is open 
until closed by terminating the command (press [.]EXECUTE/END) or by opening some 
other location. 

There is an easy way to open and close locations in succession. 

A prompting hyphen character “-” should now be displayed. If not, press [.JEXECUTE/ 
END. Open register location 0 again — press [EXAMINE/MODIFY] [REGISTER] NEXT 
[,]. The data you left in register 0 (22?) should appear. 

At this point you have opened register 0. To open register 1 (and close 0) simply press 
NEXT [,]. To open 2 and close 1 press NEXT [,] once again. To go backwards, opening 
previous locations, press [PREVIOUS]. Press [PREVIOUS] again. Register 0 should be 
open now. Close it by terminating the command [.]EXECUTE/END. 
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The MCS-48 has 64 registers, numbered 0 to 3F hexadecimal. All PROMPT 48 addresses 
and data are entered and displayed in hexadecimal. There are some special purpose 
locations, such as the accumulator, which we have assigned register numbers: 


Number 

Location 

40 

ACCUMULATOR 

41 

TIMER 

42 

PSW 

43 

PCL 

44 

PCH , 

45 

PORT 0 (BUS) 

46 

PORT 1 

47 

PORT 2 

48 

MISC 


Format 


CY 

AC 

FO 

BS 


S2 

Si 

So 


READ-ONLY 

READ-ONLY 


Counter 

Timer 

Timer 

Nested 

Will 

Mem 

T1 

TO 

Run 

Run 

Flag 

Fr Int 

En Int 

Bank 




Note that the PSW (register 42) as EXAMINE/MODIFied from the Prompt panel includes 
the Flag 1 FI test bit. It’s been added for ease of debugging. The real MCS-48 PSW as 
accessed by your program does not contain FI. 

Note that ports 0 and 1 (registers 45, 46) cannot be modified by EXAMINE/MODIFY. 
These can only be read. 

The bits of MISC (register 48) require explanation: 

COUNTER RUN — if your program uses the MCS-48 timer/event counter as an event 
counter you must manually set this bit to ‘‘1”. Otherwise PROMPT assumes you will use 
the timer/event counter as a timer. Your program should still use STRT CNT, STRT T, and 
STOP TCNT instructions as usual. The COUNTER RUN bit is the only way the PROMPT 
monitor can tell whether you are using the EVENT COUNTER instead of the TIMER. It 
allows the monitor to properly suspend and restart the timer/event counter when a ‘ 'break’ ’ 
occurs . 

The transition from user program to monitor program is called a "break. ’ ’ During breaks the 
PROMPT monitor takes pains to save the state of the broken user program so that it can be 
restored if you resume execution. 

For example, TIMER RUN will be set 1 on break if the timer is running. If you clear this bit 
to 0 the timer will not be restarted when execution is resumed. You should not need to 
change this bit. 

TIMER FLAG allows you manually to examine and modify the timer flag. 

NESTED FROM INTERRUPT will be set to 1 if you have broken during a routine servicing 
a monitor interrupt. This bit is used for monitor housekeeping, and ordinarily should not be 
changed. 

WILL ENABLE INTERRUPT — The monitor sets this bit to 1 if it will enable interrupts 
when you resume execution. You should not need to change this bit. 

MEM BANK is the memory bank select bit, the high order bit address bit for fetches from 
program memory . 

T1 and TO are the test inputs (READ ONLY). 
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Correcting Errors (Clear Entry) 

If you ever enter wrong COMMANDS, HEX DATA or FUNCTIONS you can easily 
correct it. Of course, if a location is “open’ ’ (as in EXAMINE/MODIFY) you merely roll in 
data until you are satisfied it is correct. At these times — when a location is “open” — the 
PREVIOUS button will open the previous location. 

But notice the PREVIOUS button is also labeled CLEAR ENTRY. At all other times, 
whenever a location is not “open”, pressing CLEAR ENTRY will abort a command or 
clear an error. Thus the CLEAR ENTRY/PREVIOUS button does double duty, and it does 
what makes sense. 

For example, press 

[EXAMINE/MODIFY] [CLEAR ENTRY]. 

Press [EXAMINE/MODIFY] [EXAMINE/MODIFY] [CLEAR ENTRY]. 

Press [EXAMINE/MODIFY] [REGISTER] [CLEAR ENTRY]. 

Whenever the monitor detects an error, such as Ud (undefined function) it will spell “Err’ ’ 
and is ready to accept new commands with the next keystroke. 


Examining And Modifying Program Memory 

Besides the 64 registers there are IK bytes of EPROM program memory on the 8748 chip. 
This program memory is erasable, programmable read-only memory. It is non-volatile, and 
can be programmed in seconds, but it requires several minutes to erase. 

To speed your design efforts, 1 Kbyte of RAM (read- write) program memory has been 
provided on the PROMPT system. This can be used in place of the on-chip EPROM 
program memory. It is volatile, but can be quickly and conveniently examined and 
modified. 

For example, press 

[EXAMINE/MODIFY] [PROGRAM MEMORY] starting at location 
[0] NEXT [,]. 

Program memory location 0 is now “open’’ and any instruction can be rolled in. The code 
for increment accumulator (INC A) is 17. Enter it. Press 

[1] [7] NEXT [,]. 

Now enter the instruction “jump to 0’’, whose codes are 04, 00. 

Press [0] [4] NEXT[,] [0] [.]END. 

You have entered a simple program. To verify it, again open up program memory location 0 
and step through the next locations. 

Press [EXAMINE/MODIFY] [PROGRAM MEMORY] [0] 
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Note you can step backwards, as with registers. Press 

[PREVIOUS] 

[PREVIOUS] 

[PREVIOUS] 

and then [.]END the command. 

We will run the simple program momentarily. 

Examine/Modify Data Memory 

The 64 registers on each MCS-48 chip are the primary “register memory” for data. But 
should more data memory be required your MCS-48 system may be expanded with 
“external” data memory. 

The PROMPT system provides 256 such external data memory locations number 0-FF. 
You can examine and modify them by pressing 

[EXAMINE/MODIFY] [DATA MEMORY] 

[0] NEXT[,] 

which opens location 0. You can roll in data and step through the next or previous locations 
as with the other EXAMINE/MODIFY commands. 

MCS-48 manuals refer to such data memory as “external” because it is outside the chip 
computer. But 256 bytes of this memory are inside the PROMPT box. Thus we will refer to 
the external data memory inside the PROMPT box. 

You can add more data memory than the 256 bytes provided in PROMPT. Simply interface 
expansion memory to the I/O ports and BUS CONNECTOR, at address IK (400i6) or 
greater. Then this expansion data memory is examined and modified by the [EXAMINE/ 
MODIFY] [PROGRAM MEMORY] keys, and appropriate addresses. 


Access Codes [A] 

Now we can explain the ACCESS codes, and run the program just entered in writable 
(RAM) program memory. 

ACCESS codes allow you to specify 

a. which program memory you will use, either WRITABLE (RAM) in the PROMPT 
box or READ ONLY (ROM/EPROM) on the CPU chip 

b. how you will use Port 0 (BUS). It can be used either 

1. as a port, latched on output. Under this access OUTL PORT 0 would work; 

2. as a bus, to address expansion memory and I/O outside the PROMPT box; or 

3. as a bus, to address the PROMPT system monitor memory and HO devices. This 
mode would be used if your user program wanted to talk directly to the PROMPT 
keyboard, displays, or serial channel. A listing of the system monitor routines and 
their use is in Appendix B. 

The first two uses of Port 0 (as latched port or outside expansion bus) will be more common. 
Of course, programs can be run from READ ONLY (on-chip) memory or from its 
WRITABLE (RAM) replacement. 
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The access codes are summarized: 


Access 

Code 

Program 

Memory 

System I/O and 
System Calls 

Expansion 
Memory and I/O 

OUTL 
Port 0 

0 

WRITABLE (RAM) 

no 

no 

yes 

1 

WRITABLE (RAM) 

no 

yes 

no 

2 

WRITABLE (RAM) 

yes 

no 

no 

3 

READONLY (ON CHIP) 

no 

no 

yes 

4 

READ ONLY (ON CHIP) 

no 

yes 

no 

5 

READ ONLY (ON CHIP) 

yes 

no 

no 


You can change access codes (or enter any other system commands or functions) whenever 
the power-up message “ACCESS=0” or prompting hyphen appears. 


Here’s how. Press [A] [!] [.] END. You have selected ACCESS code 1. 
Press [A] [0] [.] END to return to ACCESS code 0. 


P2 Map [2] 

Just as ACCESS CODES establish how Port 0 (BUS) will be used, the Port 2 MAP 
command establishes the DIR (direction) of each Port 2 line. The bits of DIR map each line 
of Port 2: IN=1, OUT=0. 

[2] {DIR} [.] 

On power-up and [SYS RST] the monitor assumes all lines should be output, and therefore 
clears the P2 MAP to zero. 

Recall that MCS-48 processors use the least significant nibble (ESN) of Port 2 to address 
off-chip (expansion) program memory and I/O ports. Thus the ESN P2 MAP, the contents 
of ESN P2 and the ACCESS code are related. 

If you have selected expansion memory and I/O (ACCESS = 1 or 4) then the MAP for ESN 
P2 is ignored because ESN P2 must be bidirectional to work with the 8243 I/O expander. 
PROMPT detects when signals must flow in or out through ESN P2, and switches buffer 
drivers accordingly. 

At any other time that you access off -chip resources — whether writable program memory, 
external data memory, or expansion VO — ^the ESN P2 should be mapped output. Thus if 
ACCESS = 0 or 2, the P2 MAP should be XO, where X is user-defined. 

Said another way, ESN P2 can be used as input and mapped input only if ACCESS = 3 or 5 
and certain cautions about its contents are observed. We recommend that you use and map 
ESN P2 as input only if PO (bus) is always output, that is if your program is less than IK 
bytes and on-chip, in EPROM. PROMPT monitor calls, PROMPT system I/O, and 
accesses to data memory should not be done. 

Think of ESN P2 as an inside/outside resource switch. If the ESN of Port 2 is 3, 
corresponding to 1023io, then all memory accesses are inside the PROMPT box, to 

a. The on-chip program memory, or 

b. its writable program memory replacement, or 

c. the 256 bytes “external” data memory (“inside” the box). 
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If the LSN of Port 2 is greater than 3, corresponding to >1023io, the accesses are to 

a. Port 0 as an input/output port (ACCESS = 0, 3), or 

b. program memory, data memory, or I/O devices outside the PROMPT box 
(ACCESS = 1,4), or 

c. system monitor program memory and memory -mapped system I/O devices inside the 
PROMPT box (e.g., PROMPT serial channel) (ACCESS = 2, 5). 


There are some subtle implications . For a prograni to access the external data memory inside 
PROMPT, ensure LSN P2 3. To input on Port 0, ensure LSN P2 >3. 

Remember, LSN Port 2 can be set several ways, by 

a. manually [EXAMINE/MODIFY] -ing [REGISTER] 47 (Port 2); 

b. executing an OUTL P2, ORL P2 or ANL P2 instruction; 

c. allowing the program counter to exceed 3FF (1023io). When PC ^ 400 then program 
fetches are off-chip. The processor strobes the most significant PC nibble (e.g., 4) 
through least significant P2 nibble. 


Executing Programs (Go No Break) 

There are three ways to run a program. See the white -color- coded COMMANDS: 

[GO] [NO BREAK] 

[GO] [WITH BREAK] 
and [GO] [SINGLE STEP]. 

Let’s run the simple program we entered in writable program memory. 

000 INC A 

001 JMP 0 

First examine the accumulator. Press 

[EXAMINE/MODIFY] [REGISTER] [4] [0] NEXT [,] 
and remember its contents. Close the accumulator. 

[.] END 

Now enter [GO] [NO BREAK] [0] [.] EXECUTE. 


The user program is running in real time, mindlessly incrementing the accumulator. Stop it. 
Press [MON INT] to interrupt and break to the monitor. 

Whenever a break occurs, the program counter address is displayed together with ac- 
cumulator data. 

You can always press [GO] [.] EXECUTE to resume execution at the current program 
counter address. [MON INT] will break again to the monitor. 
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Single Stepping Programs (Go Single Step) 

Instead of running in real time, you can single-step a program. This is running as though 
there were a break after every instruction. 

Press [GO] [SINGLE STEP] [0] to prepare for single -stepping at location 0. Each time you 
press 

NEXT [,] 

NEXT [,] 

NEXT [,] (etc) 

one instruction is executed and a break occurs. Press [.] END. 

As with the GO NO BREAK command, you may omit the starting address (0) and resume 
single -stepping from the current program counter address. For example, press 

[GO] [SINGLE STEP] (no start address needed) 

NEXT [,] 

NEXT [,] 

NEXT [,] (etc.) 

[.] END. 


Setting Breakpoints (The [B] Function) 

When you are debugging larger programs you will want selectively to set several break- 
points. PROMPT allows you to set as many as eight breakpoint addresses. 

Press the [B] function. Now open up breakpoint 0. Press: 

[0] NEXT [,]. 

Probably it will contain random numbers. You can step through the entire breakpoint table, 
opening NEXT or PREVIOUS table entries by pressing 

NEXT[,] 

NEXT [,] 

NEXT [,] 

[PREVIOUS] 

[PREVIOUS] and so on. 

Press [.] END to terminate the command. 

To clear all breakpoints, press 

[B] [.] END. 

Now examine the breakpoint table. Press 

[B] [0] 

NEXT [,] 

NEXT [,] 

NEXT [,] 

and so on 
[.] END 
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Let us set a breakpoint at each instruction in our simple program. Suppose breakpoint 2 is set 
at location 0, and breakpoint 3 is set at location 1 . (Breakpoints 0,1, 4-7 remain unused.) 


Enter 

[B] [2] NEXT [,] [0] 

NEXT [,] [1] 

[.] END. 

Check the breakpoint table. Enter 

[B] [0] NEXT [,] 

NEXT [,] 

NEXT [,] 

NEXT [,] 

NEXT [,] 

NEXT [,] 

[.] END. 


Running With Breakpoints (Go With Break) 

Now press [GO] [WITH BREAK] [0] 

NEXT [,] 

NEXT [,] 

NEXT [,] 

NEXT [,] 

NEXT [,] and so on. 

After each user instruction the monitor is run; the user program counter is compared with 
entries in the breakpoint table. If the user PC is not at breakpoint, execution is resumed. 

Of course this breakpoint checking after each user instruction requires many monitor 
instructions. GO WITH BREAK runs programs about 2,000 times slower than real time. 

You can selectively clear breakpoints. Pressing 

[B] [3] [.] END 

will clear breakpoint 3. Try 

[GO] [WITH BREAK] NEXT [,] 

NEXT [ ,] 

NEXT [,] 

NEXT [,] 

[.] end 

As with the other GO commands, the starting address is optional. If you omit it, execution 
begins at the current program counter. 

You are now familiar with all of PROMPT 48 ’s commands, and a number of its functions. 
Let us cover the remaining functions. 
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Clear Memory [C] 

Allows you to clear either register, program, or data memory. Specify starting and ending 
memory address. 

For example: 

[G] [REGISTER] [0] NEXT [,] [3] [F] [.] END 
clears all 64 registers. 

[C] [PROGRAM MEMORY] [0] NEXT [,] [3] [F] [F] [.] END 


clears 1024 program memory locations. 

[C] [DATA MEMORY] [0] NEXT [,] [1] [.] END 
clears external data memory locations 0 and 1 . 

We compactly describe this function as 
[REGISTER] 

[C] ([PROG MEM]) {SMA} [,] {EMA} [.] 

^[DATA MEM] 

where SMA is starting memory address, EMA is ending memory address. 


Dump From Memory 

Dumps register, program or data memory to paper tape in the standard Intel HEX FOR- 
MAT. Assumes a teletypewriter has been interfaced to the PROMPT 48 via a PROMPT- 
SER cable. See details in Appendix C. With this function you can prepare a paper tape 
specifying your program memory pattern for volume ROM (8048) orders. 


/[REGISTER] . 

[D] ([PROG MEM]) {SMA} [,] {EMA} [.] 

^[DATA mem/ 


Enter (Read) Into Memory [e] 

Enters into register, program or data memory the contents of a paper tape punched in the 
standard Intel HEX FORMAT. 

[REGISTER] 

[E] ([PROG MEM]) {BIAS} [.] 

[DATA MEM] 

The HEX FORMAT includes both data and load addresses. A bias (ordinarily 0) is added to 
the load addresses allowing you to offset where anything is entered. 

Notice a little “r” appears when you press E. This stands for read. We have already used E 
to stand for examine/modify. 
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Byte Search Memory [4] 

Searches REGISTER, PROGRAM or DATA memory for one byte of data with optional 
mask. 

.[REGISTER] . 

[4] ([PROG MEM] A {SMA} [,] {EMA} [,] {DATA} r i 

^[DATA MEM]^ ^ L-J 


For example, press [4]. 

“SI” appears, indicating a search for one byte. Now press [PROGRAM MEMORY]. 
Notice “SI” becomes “SP”. 

Let us search between program locations 0 and 3FF for the data pattern 0. Enter 
[0] [,] [3] [F] [F] [,] [0] [.] 

The function should find the first zero at location 2. Other occurrences of zero may be 
found by repeatedly pressing 

NEXT [,] 

NEXT [,] 

NEXT [,] 


until the ending memory address is passed or [.] END is pressed. 

Think of the mask as a pattern of ones and zeroes . The ones select the bits of each byte which 
will be compared; the zero -masked bit positions don’t count. 

Formally, search stops if a match is found, that is, for all bits 

[DATA] V [MEM CONTENTS] is 0 

If an optional mask is entered then only on the bit masked “ 1 ” will the exclusive OR test be 
applied. 


Word Search Memory [5] 

Searches REGISTER, PROGRAM or DATA memory for two bytes of data with optional 
two -byte mask 

[REGISTER] r 1 

[5] ( [PROG MEM] j— {SMA} [,] {EMA} {HDATA} [,] {LDATA} — (mMASK} } 1 {LMASKf 1 

'[DATA MEM]' ' 


This function works like the one-byte search just described. HDATA is the high byte of 
data, LDATA is the low byte of data. HMASK is the high byte of mask, and LMASK is the 
low byte of mask. 
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Hex Calculator [6] 

[6] {DATA} [,] {DATA} [.] 

This function simplifies hexadecimal arithmetic by providing you with a built-in three-digit 
hexadecimal calculator. 

For example, press 

[ 6 ] [ 0 ] [,] [ 1 ] [.]. 

Both the hex sum 0+1 = 1 and difference 0— 1=FFF are displayed. 

Press 

[6] [B] [,] [A] [.] 

Both the hex sum B + A=15 and difference B— A=1 are displayed. 

Move Memory [9] 

.[REGISTER] 

[9] ([PROG MEM]A {SMA} [,] {EMA} [,] {NMA} [.] 

'[DATA MEM]' 

This function moves blocks of register, program or data memory (with starting address 
SMA, ending address EMA) to some new register/memory address NMA. 

Finally, there are four PROMPT 48 functions that deal with the EPROM and PROGRAM- 
MING SOCKET. 

Fetch EPROM [F] 

[F] {SMA} [,] {EMA} [,] {SEP} [.] 

The FETCH EPROM function will fetch the contents of on-chip program memory from the 
programming socket processor into a block of writable (RAM) program memory in the 
PROMPT box. 

The block of writable memory has starting and ending memory addresses SMA and EMA; 
the starting EPROM address is SEP. 

For example, 

[F] [0] [,] [3] [F] [F] [,] [0] [.] 

fetches the entire EPROM contents into writable program memory. 

This function will signal an error if the programming socket processor is not properly 
seated. 

Compare EPROM [8] 

The COMPARE EPROM function compares the contents of the on-chip program memory 
of the programming socket processor with the contents of the writable (RAM) program 
memory in the PROMPT box. 

[8] {SMA} [,] {EMA} [,] {SEP} [.]. 
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If the programming socket processor is properly seated this command will compare each 
writable (RAM) program memory location in the range SMA to EMA with the correspond- 
ing on-chip EPROM program memory in the range starting at SEP. 

The hyphen prompting character appears if there are no errors, otherwise the first 
mismatched EPROM address and data are displayed. 

Successive mismatches may be displayed by pressing NEXT [,]. 


Program EPROM For Debug [7] 

This is the most commonly used function for MCS-48 EPROM programming. The PROM 
to be programmed must be properly seated. The function first ensures that the top sixteen 
bytes of on-chip program memory have been programmed with special monitor re-entry 
instructions. These instructions are required to permit debugging, that is to allow transitions 
from user to monitor programs, and back. 

[7] {SMA} [,] (EMA) [,] {SEP} [.]. 

Then it will program from a block of writable program memory (SMA to EMA) into the 
EPROM (at SEP). 

Each location is verified after programming, and any errors are displayed. 


Program EPROM [3] 

This function is similar to the function [7] PROGRAM EPROM FOR DEBUG just 
described. 

However, it does not ensure that the top sixteen bytes of program memory contain the 
special monitor re-entry code. Unless an MCS-48 processor is programmed with these 
instructions it cannot be debugged using the PROMPT monitor. 


Interrupts 

The user interrupt [USR INT] key traps the processor to location 3 if interrupt is enabled. 
The [USR INT] key is ignored whenever in the monitor, e.g., during breaks as in 
[GO] [SINGLE STEP] or [GO] [WITH BREAK]. 

The timer/counter interrupt, however, will properly function only in [GO] [NO BREAK]. 
The processor traps to location 7. 

Immediately upon monitor entry (and just before exit) the [USR INT] key can be locked out 
(or unlocked) via hardware. But the timer/counter interrupt cannot be instantaneously 
turned on and off this way. Disabling the timer/counter interrupt (DIS TCNTI) takes finite 
time. Timer/counter interrupts are random with respect to your program, and could easily 
occur within the monitor before they have been disabled. 

Consider jumping on timer flag instead of trapping via interrupt in the early stages of your 
program development. The timer/counter operates as though it were “ON” only during 
user program execution — not during breaks (the monitor program). 
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APPENDIX B 
PROMPT 48 SYSTEM CALLS 


There are 9 system calls in the PROMPT -48 monitor that allow the user to access the 24 keys 
and 8-digit display of the PROMPT-48. Below are listed the entry points (for reference 
purposes) and a brief explanation of each call. 


Routine Name 

Function 

Address (Hex) 

KDBIN 

Keyboard Status Loop and Data 

7EA 

KBST 

Keyboard Status 

7E4 

KBIN 

Keyboard Data 

7E7 

REFS 

Refresh Display 

7E2 

BLK 

Blank Display 

7DC 

ENREF 

Hardware Enable of Interrupt Refreshing 

7DF 

DGSTG 

Display Hex Digits 

7F3 

DGOUT 

Update Display Buffer 

7ED 

HXOUT 

Decode and Update Display Digits 

7F0 

NOTE: All calls (except REFS) select MB1, which may necessitate programming SEL MBO after 
the call. Access codes 2 or 5 must be selected to use these calls. 


KDBIN (Address 7EA) 


Function: Reads keyboard. If key is pressed when routine is entered, looping occurs until 
the key is released and a new key is pressed. Then the character is returned in A and sets FO if 
it is not a hex digit, i.e., one of the 8 control keys. Hex keys return exact hex value. Key 
debouncing is done on this call. 


Control Key Values 

PREV = 
PROG = 
DATA = 
REG = 


lOH 

EXAM 

= 14H 

IIH 

GO 

= 15H 

12H 

NEXT 

= 16H 

13H 

EXECUTE = 17H 


Reg. used: A, RO, R6, R7, P2, FO 
Reg. modified: A, RO, R6, R7, P2, FO 


Parameters expected: None. 
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KBST (Address 7E4) 

Function: Checks keyboard status. Returns 

C = 0 = no key pressed 
C = 1 = key pressed. 

Reg. used: A, RO, P2 
Reg. modified: A, RO, P2 
Parameters expected: None. 


NOTE 

This also applies to control keys such as “GO” which means your program 
may catch the “GO” key still depressed from the initiation of the program. 
There is no key debouncing done on this call. 


KBIN (Address 7E7) 

Function: Same as KDBIN except this routine reads the keyboard directly and does no status 
checking. Used with KBST above. Key debouncing is done on this call. 


REFS (Address 7E2) 

Function: Refreshes one 7- segment character every time it is entered and sequences through 
the entire display every 8 times. Displays decimal points from decimal point mask (see 
below). This routine is generally interrupt -driven from loc. 3., i.e.: 

ORG3 
IMP REFS 

Reg. used: A, R24-R26, R30, R31, P2 
Reg. modified: R24-R26, R30, R31, P2 
Parameters expected: See figure B1 below. 

A. loc. 38-3F: Display buffer. Contains digits to be displayed. (LED bit pattern 

form. See DGSTG.) 

B. loc. 37: Refresh count, i.e., which digit is to be refreshed. Updated every 

time routine is called so initial value can be 1-8. 

C. loc. 36: Decimal point mask. “1” bit in any or all bit positions causes the 

decimal point to be displayed in the corresponding display position. 
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3F 

3E 

3D 

3C 

3B 

3A 

39 

38 

37 

36 

35 


20 

1F 


18 

17 


08 

07 


00 


— 


— 


DISPLAY 

____ 


DIGITS 



BUFFER 


— 

(IN LED CODE) 

— 

REFRESH CRT 

DECIMAL POINT MASK 




— 

RBI 

— 


STACK 


RB0 


Figure B-1: Register Memory Map 


BLK (Address 7DC) 

Function: Blanks entire display. 
Reg. used: A, RO, R7 
Reg. modified: A, RO, R7 
Parameters expected: None. 
NOTE: Modifies loc. 37-3F. 


ENREF (Address 7DF) 

Function: Enables the automatic display refresh mechanism on the PROMPT -48 (ORs 
refresh timer into external interrupt system). 


Reg. used: A, RO, P2 
Reg. modified: A, RO, P2 
Parameters expected: None. 
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DGSTG (Address 7F3) 

Function: Converts hex digits into LED bit patterns and inserts them in the appropriate 
positions of a display buffer. Buffer is 8 bytes long (one for each display digit) and is located 
at 38H-3FH. See Figure B-1. This routine suppresses leading zeros. 

Reg. used: A, Rl, R2, R7, FO 

Reg. modified: A, Rl, R2, R7, FO 

Parameters expected: 

A. R7: Number of hex digits to be converted 

B. Rl: Address of the most significant byte where the most significant hex 
digit is stored 

C. RO: Address of the most significant digit in the display buffer that is to be 
updated (i.e., 38 to 3F). 

Typical sequence would be: 

a. load hex buffer 

b. CALL DGSTG 

c. CALL ENREF (only done once) 

d. EN I (only done once) 

The next two routines are used as a part of the DGSTG routine but may be called separately . 


DGOUT (Address 7ED) 

Function: Moves character (in LED bit pattern form) into display buffer. 

Reg. used: A, RO, R2 
Reg. modified: A 
Parameters expected: 

A. RO: Location in display buffer (38-3F) in which character is to be inserted 

B. R2: Character to be displayed. 

HXOUT (Address 7F0) 

Function: Decodes hex digit into LED bit pattern then performs DGOUT routine. 
Reg. used: A, RO, R2 
Reg. modified: A, R2 
Parameters expected: 

A. R2 LSN: Hex digit to be displayed 

MSN: Don’t care 

B. RO: Same as DGOUT. 
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fiSH48 :Fl:SVSCflL PflffiLENGTH (52) 
ISIS-II ^8 flSSeSLER. VI. 2 


LX OBJ SEQ SOURCE STflTEl€NT 

0 

1 

2 

2 iPROQFiflM mi: ^SYSTEM CfiLLS" EKfWLE FX PROMPT 48 

4 

5 ; FUNCTION: PROGRftN REfiDS THE KEVBOf^D ON THE PROMPT 48 

6 .jfiND SHIFTS THE CHfiRXTER INTO fl HEX BUFER. IT THEN 

7 ; DISPLAYS THE FX BLPFER ON T^€ 8 DIGIT LED DISPLAY. 

8 iANV Cf m D3NTRX KEYS MILL XT AS THE DELIMITER 

9 .iCXlSING m DISPLAY TO BE BLAW(ED AND RESTffi?TIN6 

10 ;THE ENTRY PRiXESS. IF MORE THAN 8 CHRRXTERS ARE 

11 ; ENTERED EtFORE THE DELIMITER THEY MILL BE SHIFTED 

12 ; INTO THE LSD AND THE MSD HILL BE LOST. 

12 



14 ; ENTRY POINTS FOR MONITOR CALLS. 

15 


07DC 

16 BLK EQU 7DCH 

; BLANK. DISPLAY 

07F2 

17 DGSTG EQU 7F2H 

i DISPLAY Rxmrc 

07DF 

18 ENREF EQU 7DFH 

.i ENABLE REFRESH 

07EA 

19 K[>BIN EQU 7EAH 

i KEYBiMD ROUTINE 

07E2 

20 REFS EfQU 7E2H 

21 

22 ; BUFFER AND MASK! POINTERS 

; REFRESH RiMIfC 


22 


0020 

24 HBFPTR im 20H 

.iLSB OF HEX BUFFER 

002F 

25 DBFPTR EQU 2FH 

;MSB iJF DISP BUFFER 

0026 

26 DPMPTR EQU 26H 

27 

28 .PROGRAM COT^TANTS 

29 

.: DECIMAL POINT MASK 

0000 

20 DPMASK EQU 0 

j DECIMAL POINT MASK 

0004 

21 HBUFL EQU 4H 

22 

;HEX BUFFER LENGTH 


22 ; INTERRUPT VECTOR INITIALIZATION 

24 

0000 

25 ORQ 0 


0000 E5 

26 SEL MB0 


0001 0409 

27 JMF* MAIN 

28 

29 i EXTERNAL INTERRIPT VECTOR 

40 


0002 E4E2 

41 IMP REFS 

42 

42 .i TIMER INTERRLPT 

44 

.;REFR DONE ON INTERRIPT 
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ISIS-II 8048 fiSSEHBLER. VI. 2 


LOC OBJ 

SEQ 

SOURCE 

ST0TEMENT 


eee? 

45 

ORG 

7 


0007 E4E2 

46 

JMP 

REFS 



47 





48 i INITI0LI20TION OF DISPL0V, 

HEX BUF 0ND REFR MECH 


49 




0009 1435 

50 M0IN; 

CALL 

CLRHX 

;HEX BUFR aRD 

00^ F4DC 

51 

CflLL 

BLK 

JBL0NK DISP 

@0^) E5 

52 

SEL 

NB@ 


000E B836 

53 

NOV 

R0..#DPNPTR 

i INIT DEC FT MRSK 

0010 2300 

54 

NOV 

A,#DPNASK 


0012 00 

55 

NOV 

0R0.A 


0013 18 

56 

INC 

R0 

; POINT TO REFR CTR 

0014 2308 

57 

NOV 

A.. #8 

i INIT Vffl. OF REFR CTR 

0018 00 

58 

NOV 

mA 


0017 F4DF 

59 

CfiLL 

ENREF 

jHRDW EN0BLE OF REFR 

0019 E5 

60 

SEL 

NB0 


0010 05 

61 

EN 

I 

; REFRESH ST0RTS 


62 





63 iGET KVBD CH0R 0ND C«CK IF DELIMITER 


64 




miB F4E0 

65 miNl; 

CflL 

KI^IN 

iGET CHFR 

001D E5 

66 

SEL 

MB0 


001E 95 

67 

ca 

F0 


001F B628 

68 

CQ 

JF0 

HEXDG 

;VES-I€X DIGIT 


QP 

70 lom 

AND START OVER IF CONTROL CHAR: 


71 




0021 1435 

72 

CALL 

iXRHX 


0023 F4DC 

71 

CALL 

BLK 

;BLfM< DISPL0V 

2m E5 

74 

SEL 

NE:0 


0026 041B 

75 

JNP 

MAINl 



76 





77 ;HEK DIGIT - SHIFT INTO HEJ^ BUFFER TICN DISfl0V' BLFFER 

0028 143F 

1 O 

79 H£m . 

CALL 

HEKFL 

..SHIFT INTO HEX BUFFER 

0020 BF08 

m 

NOV 

R7..#HBUFL*2 

:>m iDF DIG TO CONVERT 

002C B923 

81 

NOV 

Rl.#HBFPTR+3 

.iNSB OF BUFFER 

002E B83F 

8:2 

KN 

R@..#C)EfPTR 


0030 F4F3 

83 

caL 

DGSTG 

: CONVERT AND DISP BUFFER 

0032 E5 

84 

SEL 

NB0 


0033 041B 

85 

JNP 

NAINl 



Ob 

87 





88 





89 ismmims 




90 





91 ; SUBROUTINE FLECTION: CLEHR HEX BUFFER 
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Prompt 48 


Prompt 48 System Calls 


ISIS-II 8048 flSSEHBLEF!, VI. 2 

LOC OB-J SEQ SOURCE STflTErtENT 


92 .;REG USED: fi,R0..R2 
9:<;REGfW: fi..R0..R2 
94 


0035 

B826 

95 CLRHX: 

tw 

R0.#HBFPTR 


0037 

Bfl04 

96 

MV 

R2.#J®JFL 

;LOOP COUNT 

0039 

2? 

97 

fJLR 

ft 


003fi 

m 

98 CLRHXl: 

MOV 

mfl 

iCLfftR HEM LOC 

003B 

18 

99 

INt; 

R0 


003C 

EflSfl 

100 

OJtC 

R2,aR>«<l 


003E 

82 

101 

RET 




102 

103 


104 .iSIXROUTINE FIMTION: SHIFT fiiXUM LSN IHTO HEX BIFFER 

105 ;REG USED: fl..Rl..R2 

106 ;REG MOD: fl..Rl.R2 

107 


003F B920 

108 HEXFL: 

MOV 

Rl.. #f€:FPTR 


0041 Bfi04 

109 

MiJV 

R2.#HBUFL 

.;LOOP COUNT 

0043 21 

110 HEXFLl: 

XCH 


;GET LON DIGIT PftIR 

0044 47 

111 

sm 

ft 

.iSHftP NIBBLES 

0045 31 

112 

XCHD 

ft,0Rl 

; INSERT ft LSN 

0046 21 

113 

XCB 

ft,0Rl 

; RESTORE BVTE 

0047 19 

114 

m 

Rl 


0048 Efl43 

115 

DJNZ 

R2, HEXFLl 


004fi 83 

116 

RET 




117 





118 

END 




USER SVMBOLS 


BLK 

07DC: 

CIRHX: 0035 

CLRHXl 003ft 

DBFPTR 003F 

DGST6 

07F3 

DF’lfiSK 00€« 

DPMPTR 0036 

enr:ef 

07DF 

HBFPTR @020 

HEJLFL 

0004 

HEXDI3 0028 

HEXFL 

003F 

I€XFL1 0043 

KDBIN 07Efl 

MftIN 

@009 

MfllNl 001B 

REFS 

07E2 







flSSEMBLV CCWPLETE.. NO ERROFKS) 


B-7/B-8 




APPENDIX C 

PROGRAMMING EXAMPLE: STOPWATCH 


Problem Definition 

Assume that you wish to write a program that will allow Prompt-48 to function as a 
stopwatch. As always, the first step in accomplishing this task is to define exactly what you 
want the program to do. At a minimum, a stopwatch must be able to stop, clear, start, and 
display the contents of a timer. The timer must have a resolution suited to the intended use of 
the stopwatch. Since the purpose of this program is to illustrate programming techniques, 
you can be arbitrary and give the timer a resolution of 1/100 second. Let’ s go further and add 
two more things for the stopwatch to do: freeze the display at the current value of the timer 
while allowing the timer to continue running; release the display to show the contents of the 
timer. This will allow the stopwatch to function as a ‘Tap counter.” 

Now that you have a slightly better idea of what the program is to do, you can take a stab at 
dividing it into submodules. The first and most important submodule is the module which 
decides what is to be done on the basis of keys pressed by the user. This module can be 
thought of as the executive, as it is given control of the program at the start, and control 
invariably returns to it after each command is executed. We will call this module the User 
Control Functions (Commands) module. 

The User Control Functions (Commands) module must have at least indirect access to the 
LED display on the Prompt-48 panel. The module which contains the routines to take care 
of the display will be called the Display Functions module. 

The Data Functions module will give the User Control Functions module the means to read 
the panel keyboard, clear the variable TIME, and correctly add 1 to the minutes, seconds, 
and hundredths of seconds of TIME. 

The last major submodule of the stopwatch program is the Timer Control Functions module. 
This module contains the routines which start, stop, and reset for 1/100 second to overflow 
that MCS-48 Timer register. 

The major submodules and their breakdowns into these more basic tasks are shown in Figure 
C-1. 


Modular Interfaces 

Now that we have a general structure for the stopwatch program, we can design the modular 
interfaces, or the ways in which the program modules communicate with one another. 

The User Control Functions module must request data and tasks to be performed of the other 
three major submodules. The easiest way, to establish the simple communications neces- 
sary, is to assign one or more registers to hold instructions or data passing from one module 
to another. For example, the User Control Functions module, when requesting the Data 
Functions module to add 1 to TIME, might place a hexadecimal 02 in the Accumulator 
before passing control to the Data Functions module. The Data Functions module would 
then examine the Accumulator to see what was being requested of it, having been written 
with the knowledge that hex 02 means ‘‘add 1 to TIME.” Any combination of Registers, 
user Flags, or Data Memory locations can be used in this way to accomplish a given 
programming task. 





Programming Example: Stopwatch 


Prompt 48 


User 

Control 

Functions 

(Commands) 


Stop Stopwatch 
Set time to 0 
Start Stopwatch 
Freeze Display 
Free Display 


Stopwatch 


Clear LED Display 

Display 

Functions '' Enable Automatic LED Refresh 

Display TIME in LED’s 


Set TIME to 00:00:00 
Add 1 to TIME 

Data _««« 

Functions Check Keyboard Status 

Read Keyboard for Command 


Timer 

Control 

Functions 


Reset Timer with 1/100 sec. to Overflow 
Start Timer Running 
Stop Timer Running 


Figure C-1: Stopwatch Program Structure 


This concept can also be used in another way, called “switching.” A switch is appropriate 
in the stopwatch program for the purpose of freezing the LED display at the value of TIME 
when the freeze command is received from the keyboard. The Display TIME in LED’s 
submodule of Display Functions module needs to know whether or not the display is 
“frozen. ’ ’ This information can be stored in a bit of a Register or Data Memory location, or 
in a user Rag, by the module deciding to freeze or unfreeze the LED’ s, and later examined 
by the Display TIME in LED’ s module to see whether a new value should be displayed. This 
switch amounts to the ability to turn on or turn off the automatic update of TIME in the 
LED’s. 


These concepts are used in the actual stopwatch program, and are commented upon in the 
program listing. 
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Programming Example: Stopwatch 


Display Functions 

Control of the Prompt -48 panel LED’s is handled through the use of various System Calls 
(see Appendix B). These System Calls make it extremely easy to display whatever 
numerical data we wish in the LED’s. 

The System Calls used for display are BLK, ENREF, and HXOUT, each of whose use is 
described in Appendix B. It should be noted that the actual LED refresh is handled on 
interrupt from Program Memory location 03 . This interrupt is automatically generated by 
the Prompt -48 hardware after the ENREF System Call is used. 


Data Functions 

TIME is held in three consecutive bytes of Register memory, representing minutes, 
seconds, and hundredths of seconds. These values are in decimal, requiring the capability to 
add in decimal arithmetic instead of hexadecimal. This is easily accomplished with the 
DA A (Decimal Adjust Accumulator) instruction, as described in the MCS-48 Assembly 
Language Manual. A problem still remains in that seconds can never exceed 59io. The Add 
1 to TIME module must examine the result of adding 1 to seconds in the event of a carry 
from hundredths. If the seconds portion of TIME is equal to 60, it is set to 00 and 1 is added 
to minutes. This is called modulo arithmetic, with seconds being maintained mod(ulo) 60. 
Decimal notation is mod 10, as no single digit is ever allowed to exceed 9. 

The keyboard status is checked, and the keyboard read, through the use of two System 
Calls, KBST and KBIN. 


Timer Control 

The value loaded into the Timer should result in a 1/100 second delay to when the Timer 
overflows and sets TF (Timer Flag) = 1. To determine what the proper value is, we note 
that the Timer gets incremented every 32 instruction cycles, or 1/480 the clock crystal 
frequency. The standard MCS-48 Chip -Computer runs at a maximum frequency of 3 MHz, 
so the Timer will increment 1/480 x 3 MHz = 6250 times a second, or 62.5 times every 
1/100 second. The value to be loaded into the Timer should therefore allow the Timer to 
increment 62 times before overflow occurs. This value is computed by taking the hexadeci- 
mal equivalent of -62io, which is C2iq. This will equal OOie plus a carry (overflow, or 
TF = 1) when it has been incremented 62io times. For maximum accuracy, the .5 in 62.5 
must also be taken into account. This is accomplished by delaying Vi of a Timer increment 
(16 instruction cycles) between overflow of the Timer and the next load of —62. 


C-3 



Programming Example: Stopwatch 


Prompt 48 


asffi46 : t 1 : stpwch 


lSlS-11 iiC3-4b/liPl-4 1 MAChO A^SLHELfih , V2*0 


PAGE 1 


LOG ObJ 


SEQ SGUKCE SlAlEhEl^T 


1 

2 

3 

4 

5 

6 
7 
b 
9 

10 
1 1 
12 
13 

1 4 

15 

16 
17 
16 

19 

20 

2 1 
2 2 
2:^3 

24 

25 
2 0 
27 
2b 

29 

30 

31 

32 

33 

34 

35 
3 6 
3 7 


$print( :10: ) 

$ page wid tn ( 60 ) pageleng th ( 6 6 ) noobject 


; Prompt~4b Programming Example: Stopwatch 

; Ihis program it intended as an illustration of medium 
; complexity programming techniques for the hCS-46 
; family of Chip-Computers, to be run in Prompt-4b* 

; The complete and verified program will allow the user, 
; if desired, to observe the Prompt-46 computer in 
; action almost immediately upon delivery, and will 
; give him or her a practice example for EPhG^J burning 
; as well^ ^without needing to know anything of the 
; PiCS-4b assembly language in which Stopwatch is 
; written, the user can simply enter into Program 
; Memory the sequence of (hexadecimal) object code 
; which appears in the second (GbJ) column of this 
; listing* (hefer to Appendix A, “A Familiarization 
; Exercise'*, for key sequences used for entering and 
; examination of Program Memory contents*) i\iote that 
; there are two jumps in the normal sequence of 
; addresses (found in the LOG column) in the program: 

; 4h to lOOn, and 1JJ5b to 200h* These jumps are 
; made as a programming convenience arising from the 
; MCS-4b Program Memory paging feature. Once the 
; whole object file is correctly entered, and the 
; correct Access Mode is specified, the Stopwatch 
; will be operational. hefer to the listing for 
; program use and command key 'aef initions* 

; If FAm Program Memory is usea, use Access Mode 2. If 
; the program is burned into an 6746, use Access Mode 5* 

Reject 
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Programming Example: Stopwatch 


151S-11 hCiS-4b/Ut^l-Ml hiiChO AbSLl'ibLth, Vk*0 


P A G b 2 


LOG GbJ 


GhW 


G G U h G h G 1 A ‘1 b h b b 1 


3G 

39 

40 
4 1 

42 

43 

44 
4 3 
46 
4 7 
46 
49 
30 
3 1 
3 2 
33 
3 4 
33 
3 6 
37 
36 
3 9 
60 
6 1 
6 2 
63 


; program structure in t.ierarchical irorm: 

; btopwatch 

; I 4 User Gontrol tunctions (bxecutive Section) 

; la* Start Stopv^atch (LGGj key) 

; 1D^ Stop Stopwatch (LbhbAk] key) 

; 1 c * freeze 6 i s p 1 a y i L b X A Pi J key) 

; 16* free Display CLksXlj key) 

; le* Stop otcpwatcii ana Giear lllnb (Lbi^bj key) 

; 2* Display functions (aisttn) 

; 2a. Giear Lbu oisplay 

; 2 d. bnaole Automatic LbD helresh 

; 2c * Li splay Tihb in LbDs 

; 3* Lata functions (datatn) 

; 3a ^ Giear llPib to 0:00.00 

; 3b* Add 1 to 1 Ihb 

; 3c* iieturn keyboard Status 

; 50* he turn Key Lata 

; 4* limer heset houtine 

4 ;e je c t 
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Prompt 48 


1 hAChO ASShhbLhh, V2.0 PAGE 3 


LOG OBJ SEw BOUhCE ST Albl^iElMl 



64 

9 





63 

; symbol 

declarations 



6 6 

9 





67 






66 

; ciisltn 

symbols 



69 





000 1 

7 0 

cirasp 

equ 

1 

;clear lea display command 

0002 

71 

e n r t s h 

equ 

2 

; enable led retresh command 

0003 

72 

a i s t i m 

equ 

3 

;display 11 HE in leds command 


( J 

74 

; aataln 

s y m D 0 1 s 


000 1 

1 J 

7 6 

c 1 r t i m 

equ 

1 

; clear TlPib com man a 

0002 

7 7 

i n c t i m 

equ 

2 

;aQQ 1 to llhE command 

0003 

76 

key St 

equ 

3 

;keyboard status request 

000^ 

7 9 

Ky da ta 

equ 

A 

;keyboard data request 


60 

9 





6 1 

; system 

call 

addresses 



62 

9 




0 7ii4 

63 

kbst 

equ 

7 e4h 

;get keyboard status 

0 7b7 

64 

kbin 

equ 

7e7h 

; ge t keyooard aata 

07 Lk 

65 

rets 

equ 

7 e 2 h 

;relresh led aisplay 


66 

9 



(on interrupt) 

0 7 B 0 

67 

blK 

equ 

7d ch 

;blank led display 

0 7 B t 

66 

enr e 1 

equ 

7 d t h 

; enable relresh interrupt 

07 t b 

69 

dgstg 

equ 

71 3n 

;aisplay luultiple hex oigits 

07 PO 

50 

hxout 

equ 

71 Oh 

;aecode and display hex digit 


91 

9 





92 

; Q a ta register assignments 


93 

9 




0 0 0 3 

94 

freeze 

equ 

3 

;lree 2 e switch in r3 

002 0 

9 5 

time 

equ 

2 Oh 

;lli*iE in r20-r22 


96 

9 





97 

; command key 

symool assignments 


90 





0 013 

99 

start s 

equ 

1 Dh 

;LGUJ = start command 

0012 

100 

stops 

equ 

12h 

;LBhEAhj = stop command 

00 1 4 

101 

i reezs 

equ 

1 4h 

;LEAAi‘iJ = Ireeze command 

00 16 

102 

trees 

equ 

16h 

; L k 6 A 1 J = 1 r e e command 

0 0 17 

103 

s tpcir 

equ 

17h 

;LEhO] = stop and clear 


104 

9 





105 

; mi seel lanecus constant 

s and addresses 


1 0 6 

9 




0036 

107 

Q p m s k 

equ 

36h 

;lea dec* point mask address 

0000 

1 06 

apot 1 

equ 

0 

;decimal points oil pattern 

006^ 

109 

donee 

equ 

100 

;debounce loop length 


1 10 






1 1 1 

Reject 
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Programming Example: Stopwatch 


i'.AChU /iSSLt‘jj:;Lt:.h, \i k *0 


AGh 4 


LGC 

ObJ 

bbW 


b G 0 h C b bi 1 A i ii h b b 1 


GOOG 


1 1b 


org 

0 

;starting adaress ol program 



113 

J 






1 U 

; start 

0 t 

program 




1 1b 





00 00 


1 1b 

start: 

sel 

m bO 

;select program mem bank 0 

00 0 1 

b A 0 0 

1 17 



exec 

;jump to executive section 



1 1b 

} 






11b 

; interrupt 

vectors 




1 b 0 

> 




00 03 


lb 1 


org 

3 

;led retresh vector address 

0003 

L ALb 

1 b b 



re Is 

; r e 1 r e s n 1 e d s 



Ib3 

Reject 
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Prompt 48 


131^-11 hCS-46/Uhl-4 1 hAChC ASbttibLth, V2*Q 


L 0 C Ob 0 


bOUhOb blATbMbbT 


executive section: 

Ihis section controis the overall program 
execution^ It communicates with the following 
rfiodules: 

1) ciisftn - display function s* Clears, 

enables for refresh, or displays 11 hb in 
leds^ 

b) datafn - aata functions* Clears llhb, aads 
1 to llhb, ohecks keyboard status, or reads 
keyboard for command input* 

3) tmrrst - timer reset* resets l'jCb~4b 
timer for 1/ICO sec* to overflow* 

start of executive: first, initialize timer, Tlhb, 
and display* 

org 1u0h ;start at page 1 

:xec: stop tent ;stop timer 

mov a,^/0 ; clear a 

mov t,a ;cleartimer 

call tmrrst ;1/100 sec delay in timer 

mov rO,?/ freeze ;point to freeze switch 

mov er0,i^0 ;uri freeze display 

mov r7,#clrtim ; clear Tlhb command 

call datafn ;data functions module 

mov r7,#aistim ; display Tlfib command 

call disftn ;display funcions module 

mov r7,#enrfsii ;enaDle led refresh command 

call disftn ; display functions module 

.eject 
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Iblb-il hCS-^b/UJt^l-4 1 hAChC ASSEhbLhh, Vk*0 


. bAGE 6 


LOG 

ijbJ 

b bo 


SOUhCE SlAlbhbi'.T 



Ibk 






163 

nov/ 

wait lor 

input coffi 0 *ands* 



164 






16 3 

t ne 

commanas 

are : 



1 6b 


LGOJ - 

start stopwatch 



167 


LbhEAK J 

- stop stopwatch 



16b 


[ E A A h J 

- Ireeze display at present lllib 



169 


LhbXl ] 

- Iree display to lollow llljb 



170 


L E h b ] — 

stop stopwatch and clear 11 lib 



17 1 






17k 

■k k -k it te 





173 






17 4 

monitor ioop^ 

Inis part ol the executive waits 



17b 


until aataln indicates a key is being 



17b 

1 7 7 


pr essea 

, or the timer overflows* 



17b 


11 a Key is pressea, the command (il aelinec) 



179 


is processea ana the executive returns 



160 


to the 

monitor loop* 



1b 1 






Ibk 


11 the 

timer overllows, one is addea 



163 


to llliE 

• Ihe display is then updated il 



164 


b h E b k b 

= 0, and the executive returns to 



163 


the monitor loop^ 



16 6 




011b 

3 4 6b 

16 7 ra 0 n i t r 

: call 

uptim ;update lli-.b il necessary 

011b 

b f 0 3 

166 


mo V 

r7,5/keyst ; keyboard status request 

0 1 1 A 

3400 

169 


call 

datafn ;data 1 unctions module 

0 110 

bb 1 6 

190 

1 b 1 


jnc 

monitr ;loop il no key pressed 



19k 

Key 

being p r e 

ssed: input command lor processing* 



193 




01 IE 

br 0^ 

194 


mov 

r7,?^kydata ; keyboard data request 

0 1^0 

3400 

193 


call 

aataln ;data lu notions moaule 



196 






197 

start stopwatch commanci? 



1 9o 




0 ^ 2 k. 

i* E 

199 


m o V 

a , r 7 ; ^ y data in a 

0 1^3 

03bb 

kOO 


aa d 

a,i(/-starts ; start command? 

0 12^ 

36kA 

kO 1 


jnz 

nextl ;jump if not 



kOk 




0 1 kV 

3 3 

:^C3 


s tr t 

t ;start timer 

u 1 ^ib 

^43E 

k04 


J«iP 

end com ;end ol command processing 



k 0 3 






k06 

not 

start: stop stopwatch c o m ni a n d V 



k07 




C 1 2A 

i? t 

k 06 next 1 : 

mov 

a,r7 ;key data in a 

0 1 k b 

0 3 b b 

k09 


ad a 

a, -stops ;stcp command? 

0 1 ko 

3 b 3k 

k 10 


jnz 

nextk ;jump il not 



k 1 1 




0 1 k i:* 

b 3 

k 1 k 


stop 

tent ;stop timer 

0 130 

k 4 3 b 

kl3 


j 

endcom ;ena cl command processing 


2 1 4 

^ 1 b 4. e j e c t 
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Prompt 48 


1 hhChO AbbEMtLLh, 


LOG 

C b O 

b b b 


,b0u hCb 



216 

> 




217 

; not 

stop : 



216 

> 


0 1 3;: 

t t 

219 

nex 1 2 : 

m 0 V 

0133 

ObbL 

2 2 0 


aaa 

0135 

9 6^2 

22 1 


jnz 



2 2 2 



0 137 

bbG3 

223 


mo V 

0139 

230 1 

22 A 


iTiO V 

0 1 3b 

AO 

22b 


mo V 

0 130 

bb03 

22 6 


m 0 V 

0 1 3£ 

3 ^ 7 b 

^27 


call 

0 1 bo 

2b9b 

226 


jmp 



22b 

y 




230 

; not 

freeze : 



231 

> 


0 1 b t 

1 1 

232 

n e X 1 3 : 

m 0 V 

0ib3 

03 A 

233 


aaa 

0 1 bb 

9b4b 

23A 


jnz 



23b 



0 1 b? 

bd03 

236 


m 0 V 

0 1 b9 

^300 

237 


mov 

0 1 bt 

A U 

236 


mov 

0 1 bO 

2 Abb 

239 


Ji-P 



2 AO 

y 




2 A 1 

; not 

free: 



2A2 

y 


0 1 bo 

t r 

2A3 

n e X t A : 

mov 

0 1 bf 

0 3bb 

2 A A 


aaa 

0151 

bobn 

2Ab 


jnz 



2 A 6 



0 1 53 

db 

2A7 


stop 

0 15b 

b^bb 

2 A 6 


call 

0 15 6 

bt 0 1 

2 A9 


mov 

0 1 5o 

bbOO 

2 bO 


call 

0 1 5* 

b b 0 3 

2 b 1 


mov 

0 150 

3 A 7 b 

2 b 2 


call 



2b3 





2 b A 

Reject 



7 


STAltLhEhl 


reeze cotniriand V 

a,r7 »i<-ey data in a 

a , # - 1 r € e z s ; 1 r e e z e c o m m a n a V 
nextS ;junip il not 

rO,^/lreeze ;point to 1 reeze switch 
a , iM ; t r e e z e display*' 

erO,a ;set freeze switch 

r 7 , ci i s t i m ; d i s p 1 a y 1 1 . L c o lu n: and 
aisltn ;dispia> lunctiohs cioauie 

e n G c o a: ; e n a o 1 c o i:i rh a n a processing 

free ccinmandi 

a,r7 ;^ey oata in a 

a , - 1 r e e s ; 1 r e e c o rn ma n a V 
nex t^ ; jump il not 

rO,i/ freeze ; point to freeze switch 
a , 0 ; “ f r € e a i s p 1 a y " 

erO,a ;clear freeze switch 
endcorn ;enQ of command processing 

top and clear command, or undefined key, 

a,r7 ;key aata in a 

a,//-stpclr ;stop ana clear command? 

endcorn ;jump, undefined if not 

tent ;stop timer 

tmrrst ;£top and reset timer 
r7,*-clrtim ; clear time command 
aatafn ;aata functions moaule 
r 7 , cl i £ t i m ; a i s p 1 a y 1‘ 1 i'‘ . h command 
Qisftn ;ai splay functions module 
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hub- 

kb/btl-^y hiiCho fiijbthtLth , 

V2*0 bAGL 6 

LUC 

Ub J 

bbU 

bObhUL 

b 1 A 1 b I’ j L 6 i 



255 





2 56 

end oi commanc processing: v,'ait tor the key. 



2 57 

to be 

released, tlien return to the monitor 



250 

1 0 0 p ^ 




2 1>5 



0 1bL 

3 4 6 0 

2o0 endcofli: call 

uptim ;update lli-ib il necessary 

U 1 oO 

tb0 3 

26 1 

n:o V 

rl , if key St jKeyboara status request 

GILL 

5400 

262 

call 

dataln ;data lunctions module 

C 164 

f 0 5L 

263 

jc 

enacoiTj ;locp until key released 



2 6 4 



0 1 bo 

2416 

265 


monitr ;return to monitor loop 



266 





267 





2 6 0 

uptiiTi - update lli^ib il necessary^ bubroutine 



2 6 5 

to check the status of 1 ( 1 i rn e r blag), and 



2 70 

add 1 

to limb i 1 'if = 1 ^ 6 a t a 1 n (Lata lunctions) 



271 

module 

is used to add 1 to 11{\L* 



212 





21 b 

reg iuoaitied 

: a , r 0 , r 2 , r 7 



2n 



0 160 

1 6 6U 

2 7 5 u p t i ra : j 1 1 

next5 ;sicip aheaa il If = 1 



2? 6 



0 1 6A 

2 4 7 o 

277 


uptxit ;jump to exit if If = 0 



2 1 0 



0 1 6U 

5456 

279 next5: call 

tmrrst ;1/100 sec delay lor timer 

0 1 OL 

bb0 2 

2 0 0 

mo V 

r7,vifictim ;add 1 to 'ilhb command 

U 1 7 0 

5400 

20 1 

call 

dataln ;aata lunctions module 

0 17 2 

b 6 0 3 

2 b k. 

mo V 

rO,^/ freeze ;point to Ireeze switch 

0 17 4 

6 0 

263 

mov 

a,er0 ;lreeze switch in a 

0 176 

6300 

2 o4 

xr i 

a .if Q ; ireeze switch = 0? 

0 177 

667 L 

205 

jnz 

uptxit ;jump to exit it not 



2 6b 



0 176 

b t* 0 3 

20 7 

mov 

r7,#distim ; display lliiL command 

0 1 7 6 

3 4 7 L 

2 6 6 

call 

disltn ; display functions module 



2o9 



0176 

63 

290 uptxit: ret 

;exit uptim 



29 1 





292 





29 3 

eriQ ol executive section 



29 4 





2 9 5 





2 964ieject 



C-11 



Programining Example: Stopwatch 


Prompt 48 


ISlS-ll 1-4 1 t-iACRO A6 i>t,hbLth , V i: . 0 


r AGL 


LOG ObJ 


SbO 


>OUhGc, SlATbi-itLT 




297 

t 



296 

» 





2bb 

; disttn - aisplay iunctions module. Ihree commands 



300 

> 

are executed by this module: 



30 1 

> 





302 

1 

1) clrdsp - clear led display 



303 

1 

r eg 

m 0 d i 1 i e d : a, r 0 , r 7 



304 

f 





3Gb 

f 

2) enrlsh - enaole automatic led re Ires h 



3 0 6 

i 

reg 

modilied: a, rO, r7, p2 



307 

t 





30 6 

> 

3 ) dis 

tim - display llhL in leos 



309 

7 

reg 

m o d i 1 i e d : a , r 0 , r 1 , r 2 , r 7 



310 

7 





311 

7 





312 

; 1 h e 

com ill and 

isreceiveo in r7* Ibe module is called 



313 

7 

a s a s 

uoroutine . 



314 

7 





31b 

} 




316 




0 1 7h 

t't 

317 

d i Si tn 

: in 0 V 

a , r 7 ; c o m n j a n d in a 



31b 






31b 

7 





320 

; clrosp comma 

n d V 



321 

7 



0 1 7 

G 3 f ^ 

322 


add 

a. ,?/ - clrdsp ;clrasp command 7 

U 161 

b 0 b 6 

323 


jnz 

nextb ;jurrjp il not 

0 163 

t* 4GC 

32 b 


call 

Dlk ; blank leds sys call 

Glob 

Lb 

32o 


sel 

m b 0 ; I i X program ivi e n: ban k 

Glob 

L b 

327 


Jfltp 

dspxit ;jump to exit 



32b 

7 





32 9 

; not 

clrdsp : 

enrlsh command V 



3 30 

7 



Gibb 

1 1 

331 

n e X t b : 

mo V 

a , r 7 ; c 0 n: ma n d in a 

Gibb 

OjtL 

3 32 


ado 

a, //-enrlsh ;enrlsn corrimand? 

G 1 (jL 

b b b it 

333 


jnz 

n e X 1 7 ; J u m p i 1 n 0 1 



334 




G 1 OL 

L 0 3 b 

3 3b 


mo V 

r0,/^dpmsK ;point to decimal point mask 

0 1 6f 

lGGG 

336 


mo V 

fcr0,j7dpoll ;decimal points oil 

Olbl 

1b 

3 37 


inc 

rO ;point to relresh char pointer 

01b2 

LGOb 

3 3b 


mov 

er0,//b ;led b lirst 

G 1b4 

t‘ kb t 

339 


call 

enrel ;enable led relresh sys call 

Gibb 

Lb 

340 


sel 

mbO ; 1 ix program mem bank 

G1^7 

Ob 

341 


en 

i ; enable relresh interrupts 

Gibb 

kk bb 

342 


J P 

dspxit ;jump to exit 



343 

Reject 
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Prompt 48 


Programming Example: Stopwatch 


lSiS-11 

LCb- 

4b/UPl-41 hAChO iibShhbLth , 

Vi: .0 

bAGb 10 

LUC 

0 b J 

SbC 

SCOhCb 

ijTAlhhthl 




3^4 

» 





345 

; not e n r t s h : 

either distim or undefined command 



34b 




01 9A 

bi* 

347 

next?: m o v 

a,r7 

command in a 

oiyb 

0 3^0 

34b 

ado 

a,# -distim ;unde fined command? 

0 19L 

9 Ob b 

349 

jnz 

ds px i t 

jump to exit if so 



350 






351 

; display minutes 




352 




019b 

b 0 3 b 

353 

mov 

r 0 , 3 e h 

led address of minutes 

01 A1 

b920 

354 

mov 

r 1 ^ if time 

; minutes portion of llhb 

01 A3 

b b 0 2 

35 5 

mov 

r7 , 2 

2 digits to be displayed 

0 1 Ab 

t Ah 3 

350 

call 

dgstg 

convert and display 

0 1 A7 

bb 

357 

sel 

mbO 

, fix program mem bank 



35b 






35 9 

; display seconds 




3 00 




0 1 AO 

bb 3 b 

301 

mov 

r 0 , 3 0 h 

msd led destination 

0 1 AA 

b92 1 

302 

mo V 

r1,#time+1 ;seconds portion of Tlhb 

0 1 AC 

t 1 

303 

mov 

a , 0 r 1 

move seconds to a 

0 1 AL 

47 

3 0 4 

s Via p 

a 

msd in Is nibble 

0 1 AL 

AA 

3 05 

mov 

r2,a 

hex display data - msd 

0 1 Ab 

h-4b0 

3 0 0 

call 

hxout 

display seconds msd 

Olbl 

bb 

307 

sel 

ffi bO 

fix program mem bank 

0 ILL 

b1 

3 0b 

mov 

a , 0 r 1 

move seconds to a 

OILS 

AA 

309 

mov 

r2 , a 

hex display data - Isd 

OlbA 

Cb 

37 0 

dec 

rO 

Isd led destination 

Oibb 

h'4b0 

371 

call 

hxout 

display seconds Isd 

OIL? 

bb 

372 

sel 

mbO 

fix program memory bank 



373 






374 

; display hundredths of seconds 



375 




0 1 bo 

bb3A 

370 

mov 

r 0 , f/ 3 a h 

;seconds Isd led address 

0 1 bA 

bO 

37 7 

mov 

a , b r 0 

led code in a 

Gibb 

b37b 

37b 

a n 1 

a , f h 

decimal point on 

Gibb 

AG 

379 

mov 

b r 0 , a 

replace in led buffer 

Gibb 

Cb 

3 0 0 

dec 

rO 

msd led destination 

0 1 bb 

b9 2 2 

3b1 

mov 

r1,#tinie + 2 ; hundredths portion of llfib 

01C1 

t 1 

302 

mov 

a , 0 r 1 

hundredths in a 

01C2 

A7 

303 

swap 

a 

msd inis nibble 

0 1C3 

AA 

304 

mov 

r2 , a 

hex display data - msd 

01C4 

b4b0 

305 

call 

hxout 

display hundredths msd 

0 1 Cb 

b5 

3 bo 

sel 

rn bO 

fix program mem bank 

01C7 

Cb 

3 07 

dec 

rO 

Isd led destination 

0 1C6 

t 1 

30 0 

mov 

a , 0 r 1 

isd hex da ta 

01C9 

AA 

309 

mov 

r2 , a 

hex display data - Isd 

0 1 CA 

b4f 0 

390 

call 

hxout 

display hundredths Iso 

0 ICC 

bb 

391 

sel 

mbO 

fix program mem bank 



392 






393 

; clear unused 

leds 




394 




01CD 

bb 3h' 

395 

mov 

r 0 , 3 f h 

leftmost led 

OlCb 

bOb b 

390 

mov 

er0,#0ffh ;clear leftmost led 

Olbl 

bb3C 

397 

m 0 V 

r 0 , /o c h 

led between minutes, seconds 

0 1b3 

b 0 b h 

390 

mov 

er0,b0ffn ;clear it 
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Programming Example: Stopwatch 


Prompt 48 


bir'i-M 1 KAChG ASbLhbLth, V2.0 PAGE 


b 0 C 0 E tj 


GhG GOUhCii SiA'iEMiLbl 


0Mb 63 


39 9 
400 

40 1 

402 

403 

404 
403 
4 0b 
A07 
4 0b 
4 0 9 
4 1 0 
4 1 1 


aisttn exit point 


cispxit: ret 


end ot aisltn moaule 


Reject 


exit Qisi tn 


1 1 
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Prompt 48 


Programming Example: Stopwatch 


l^lS-11 1 hACKO ASSbl'-.bLLh , V2.0 


PAGE 


LOG ObJ 


SEG bOUKCE 51 A1 bhEbl 


0200 


02 00 


0201 

0203 y0l3 
0203 2300 

0207 b620 

0209 bb03 

020b AO 

020c 10 

020b bbOb 
020E 1611 


0211 443c 


4 12 

413 

414 
413 
4 1 6 
417 
4 1 b 

419 

420 
42 1 

422 

423 

424 
423 

42 b 
427 
42b 
42^ 

430 

431 

43E 

433 

434 
433 

436 

437 
430 

439 

4 4 0 
44 1 

442 

443 

444 
443 
44b 

447 

4 4b 

449 

430 

43 1 

432 

433 

434 
433 

43b 

437 


436 


439 

460 
4 6 1 
462 


org 


2 OOh 


program mem page 


aatafn - data funcions module. lour commands 
are executea by this module: 

1) clrtim - clear llbE* bets Tlhb to 00:00:004 
reg mooitied: a, rO, r7 

2) inctirn - increment TlEE* Adds 1 to llhE. 
reg moaitiea: a, rO, r7 

3) key St - Key status. beter mines v.hether 
a key is being pressed. 

output: c = 1 il a Key is pressed 

c = 0 il no Key pressed 
reg modilied: a, rO , r7 • p2 , c 

4) kydata - key data. beter mines which 
key is being pressed. 

output: r7 = key value 

reg moailied: a, rO , rb , r7 , p2 , 10, c 


; Ihe module is called as a subroutine witn the 
; command in r7 4 

> 

» 

d a t a 1 n : m o V a , r 7 ; c o m ma n d i n a 


clrtim cciVimanaV 



add 

jnz 

a, 1 /- clrtim ; clrtim command? 
next 9 ;jump il not 


rno V 

mov 

mo V 

a ,^/0 ;pbt zero in a 

r 0 ,#/time ; point to 11 EE 
r 7,?/3 ;loop counter* 

c 1 tl p : 

mov 

inc 
d jnz 

er 0 ,a ;clear one byte ol lli'iE 

rO ;point to next byte 

r 7 ,cltlp ;loop till llt‘jE = 0 


jtl 

next 12 ;ciear timer llag, to prevent 11 

li b 

» 

r 


; 4 .. 1 rorn incrementing alter clea 

n e X 1 1 : 

jmp 

dtaxit ;jump to exit 

5 e j e' c t 
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Programming Example: Stopwatch 


Prompt 48 


lSlb-11 1 hAChU ASSuKhLiLh , V2*0 


PAGE 13 


LUG 

ObJ 

bbQ 


GO 6 RGb 

G1 ATbi''jbO'I 




463 

J 






464 

; not clrtim: 

inctim command? 



4 6 3 

t 




0213 

1 1 

4 6 6 

n e X 1 9 : 

me V 

a ,r7 

; command in a 

02 1 A 

0 3 i*' b 

467 


add 

a,?/ -inctim ; inctim command? 

02 1 b 

9033 

4 6b 


jnz 

n ex 1 1 C 

;jurap it not 



4 6 9 







470 

; ado 1 

to hundredths 




47 1 





021b 

bbkk 

472 


mo V 

rO , t iine + 2 ; point to hundredths 

02 1 A 

to 

473 


mo V 

a , 6 r 0 

; m 0 V e d a t a 1 0 a 

02 1b 

0301 

474 


aaci 

a , jif 1 

;add 1 to hundredths data 

02 10 

37 

4 7 3 


da 

a 

;decin3ai adjust 

02 1b 

AO 

47 6 


rnov 

e r 0 , a 

;update tiundredths 

0 2 1 1 

Lb bo 

4 7 7 


jnc 

d taxi t 

;exit ii no carry 



47b 







^7 9 

; carry 

into 

seconds 




4 6 0 





022 1 

0 b 

461 


oec 

r 0 

; point to seconds 

0222 

bO 

462 


mo V 

a , 6 r 0 

;mcve data to a 

0 2 2 3 

030 1 

463 


add 

a , # 1 

; increment seconds 

022 3 

37 

464 


d a 

a 

;oecimai adjust 

02 2 0 

AO 

463 


mov 

erO , a 

;upda te seconds 

02 2 7 

0 3 A 0 

Hbb 


ado 

a , // - 6 0 h 

;iTjod 60 overliou test 

0223 

b 0 3 G 

467 


jnc 

dtaxit 

;exit il no overllow 



4 66 





022b 

bOGO 

469 


mov 

e r 0 , 1 / 0 

; 60 becomes 0 



490 







49 1 

; carry 

into 

minutes 




492 





0220 

GO 

493 


dec 

rO 

; p 0 i n t to minutes 

02 2 b 

t u 

494 


m c V 

a , e r 0 

;rrjove data to a 

0 2 2 i"' 

0301 

493 


add 

a , 1 

; i n c r e m e n t minutes 

0231 

37 

496 


aa 

a 

; decimal adjust 

0232 

AO 

497 


mov 

erO , a 

;update minutes 

0233 

A 4 3 G 

496 



dtaxit 

;jufrip to exit 



499 







300 

e j e c t 
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Prompt 48 


Programming Example: Stopwatch 


lbib-11 hCS-46/brl-41 t'iiiChO ASSLiibLhh, Vk.G bAGL 14 


LGC 

ObJ 

bbO 

bOu hOb 

b 1 A '1 11 h b K 1 




50 1 






502 

; not i n c t i ra : 

K e y s t c 0 m m a n d V 



dO 3 

» 



0235 

t b 

504 

n e X t 1 0 : m 0 v 

a , r 7 ; 

command in a 

0230 

0 3 

505 

aaa 

a , 1 / - K e y s t 

;keyst com m ana V 

0230 

9640 

506 

jnz 

nex 1 1 1 ; 

jump ii not 



50 7 




0 2 3 A 

bbb4 

506 

mo V 

r b , j 7 cl b n c e 

;Gebounce loop counter 



509 




023 c 

f 4h4 

510 

QDncip: call 

RDS t ; 

get key status 

0 2 3b 

b5 

5 1 1 

sei 

m bO ; 

fix program mem bank 

0 2 3 i*’ 

l6 5 0 

b12 

jnc 

a tax it ; 

exit il no key pressea 

024 1 

3 4 b 6 

513 

call 

u p t i in ; 

upaate 11 1 . l it necessary 

0243 

bb 30 

5 1 4 

Q jnz 

rb, QDncip 

;lcop till debounce done 



515 




0245 

b r'O 2 

5 1 6 

mcv 

r 7 , e n r* i s 

h ;reenaoie re Ires h of leas 

0247 

347 b 

517 

call 

a i s f t n ; 

♦ ••via d i s 1 t n m 0 a u 1 e 

024 9 

5? 

5 1 6 

cir 

> 

ensure carry is 

024a 

kl 

519 

Cpi 

c ; 

••^still set 

0^4b 

4450 

5 20 

jmp 

a taxit ; 

jump to exit 



521 

> 





522 

; not keyst: 

K y cl a t a c 0 tn m a n a V 



523 

> 



0240 

t e 

524 

n e X 1 1 1 : m 0 v 

a,r7 ; 

c 0 m m ana in a 

02 4L 

03^0 

525 

aaa 

a , 1 ^-Kyaat 

a ; k y Q a t a command? 

0250 

9056 

5 2b 

jnz 

a t ax i t ; 

(unaeiined) exit ii not 



527 




0252 

f 4 b 7 

5 <10 

call 

k b i n ; 

get key aa ta 

0254 

b5 

5 2 9 

sel 

iTi b 0 ; 

fix program men: bank 

0255 

A b 

530 

mo V 

r b , a ; 

save key data in r6 

0 2 5 6 

b bO 2 

531 

rn 0 V 

r 7 , fA e n r 1 s 

li ireenaole lea refresh 

0 2 5 6 

3 4 7b 

532 

call 

a i s i t n ; 

• ••via d i s i t n module 

0 2 5a 

b b 

533 

fiiO V 

a , r 6 ; 

get key data 

0250 

Ab 

534 

mov 

r?, a 

aata in output register 



535 






536 

> 





53 7 

; oatatn exit 

point 




5 3b 

5 





539 




0250 

6 3 

540 

at ax it: ret 

1 

exit a a t a f n module 



5 4 1 






5 4 2 

1 





543 

; e n G ci a t a 1 n 

a* 0 ci u i e 




544 

} 





545 






54 b 






547 

e j e 0 1 
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Programming Example; Stopwatch 


Prompt 48 


1S15-11 1 hAChC ASir^Li'^.bLhh , \2.Q 


tAGt 15 


LGC ObJ 


SbQ bObhCb bliilbhbbl 


546 

54 5 

55 0 
551 
5 5b 
553 
5 54 

555 
5 5 6 
5 57 

556 
555 
5 6 G 

56 1 
5 6 2 
5 6 3 
564 
5 6 5 
5 6 6 


tmrrst - timer reset module* This routine adds to 
the contents of the timer -62 (decimal)* 

It is done this kay because the timer may 
have been incrementing curing an interrupt 
routine between the detection of’ Ti* = 1 
ana the actual reset. 

-62 aecimal is the value closest to 1/100 
second delay lor a 3 ^ihz clock frequency. 

A 16 instruction cycle (1/2 timer increment) 
aelay shoula be aodea at the beginning of the 
routine, v^ith the timer stopped, for maximum 
accuracy . 


025b 

4b 

56 7 

tmrrst: m o v 

a , t 

; timer data to a 

0 2 5ii 

0362 

5 6 6 

aa a 

a , // — 6 2 

; coun ter lor 1/100 



565 

t 


second delay 

02 6 0 

62 

570 

mov 

t , a 

;reset timer 

0^:6 1 

63 

57 1 

ret 


; exi t tmrrst 



572 






57 3 

> 





574 

; end ol tmrrst 

module 



57 5 
576 


57 7 

576 4;eject 
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Prompt 48 


Programming Example: Stopwatch 


1 -b 1 ^ - 1 i l i C b - 4 o / U 1 " ^ 1 h A C h U b b L i‘-i L L b 11 , V A . 0 


rAUE 16 


LCC ULJ bbW bOui.Cb bl Al bi'-jhl/i 


0000 


6 

7 6 

e na 

0 

; e nd 

oi s 

1 0 p w a t c h 

(j b b n b 

i iibOLb 








bbK 

07b c 

C b ii b b b 

0 0 0 1 

CLhllbi 

000 1 

CLlLb 

0 2 0b 

b A 1 A b i\ 

b b i-i 0 b 

0 0 6 4 

b b A b L b 

o2 30 

b 0 b 1 0 

0 7 b 3 

b 1 b b 1 A 

0 17b 

blbllh 

bbi^bK 

0 0 36 

b b Ob t 

0000 

b b b A 1 i 

Gibb 

b'l AXll 

0 2 6 0 

b A b C 0 K 

b i\ h b t 

0 7 b r 

b A b b h 

0 002 

b Ab 0 

0 100 

r' h b bb 

00 16 

b h b b Z b 

t A b b Z b 

00 14 

b A C 6 I 

01 to 

IhCllb 

0 0 02 

b b 1 A 

0 7b7 

Kbbl 

K b 1 b 1 

UU03 

A i b A 7 A 

0 0 0 4 

liCNll 1\ 

Olio 

A b X 1 1 

C 1 2 A 

bbXT 10 

bbA'i 1 1 

02 4b 

A b A 1 1 2 

02 1 1 

b A 1 2 

0132 

A b X 1 3 

0142 

AbX14 

b X i 6 

0 16C 

b b A 1 6 

0166 

bbX17 

0 1 6 A 

A b X 1 6 

0213 

H b b b 

b '1 A h 1 

0000 

b 1 A h 'i b 

0016 

b 1 0 r b 

00 12 

blbCLh 

0017 

1 lAb 

1 i'l h h b '1 

026b 

bbllh 

0 166 

bblAll 

0 17b 





A b b L 1 1 b L i CO 1' i b L h ‘i b , A 0 bh ii 0 h b 


program 


Ob 00 
0003 

0 16b 

0003 
07 b^ 
0236 
0 1 Ab 
07bb 
0020 
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APPENDIX D 

HEXADECIMAL OBJECT FILE FORMAT 


Hexadecimal object code format is an ASCII representation of program memory, expressed 
as a series of hexadecimal digits. These are blocked into records, each of which contains the 
record length, type, memory load address, and checksum, in addition to data. 

Frame 0. Record Mark. The ASCII representation of a colon (3Ai6) is used to signal the 
start of a record. 

Frames 1 and 2. Record length in hexadecimal. This is the count of the actual data bytes in 
the record. Frame 1 contains the high-order digit of the count, and frame 2 contains the 
low -order digit. A record length of zero indicates end of file. 

Frames 3 to 6. Load address. The four-character starting address at which the following data 
will be loaded. The high-order digit of the load address is in frame 3 , and the low-order digit 
is in frame 6. The first data byte is stored in the location indicated by the load address. 
Successive data bytes are stored in successive memory locations. 

Frames 7 and 8 . Record type. A two-digit code in this field specifies the type of this record. 
The high-order digit of this code is located in frame 7. Currently, all data records are type 0. 
End-of-file records may be type 0 or type 1 . In either case they are distinguished by a zero 
record length field (see above). 

Frames 9 to 9 + 2* (record length) — 1 . Data. Each 8 -bit memory word is represented by two 
frames containing ASCII characters 0-9, A-F, which represent a hexadecimal value 
between 0 and FF (0 and 255 lo). The high-order digit of each byte is located in the first 
frame of each pair. 

Frames 9 + 2*(record length) to 9 + 2*(record length)+ 1 . Checksum. The checksum is the 
negative of the sum of all 8-bit bytes in the record, evaluated modulo 256. The sum of all 
bytes in the record (including the checksum) should be zero. 


D-l/D-2 




APPENDIX E 
COMMAND/FUNCTION SUMMARY 


Commands 


[EXAMINE/MODIFY] 


[REGISTER] V 

[PROG MEM]-) — {SMA} [, 

[DATA MEMl/ 


J- 


{DATA}- 


/[.] 

■/[,] 

\rpi 


[PREVIOUS] 




MCS 48 processors have 64 bytes of register memory numbered O-SFig. PROMPT 48 
allows access to pther “register” locations via [EXAMINE/MODIFY] [REGISTER]. _ 


Number 


Location 


Format 


40 

41 

42 

43 

44 

45 

46 

47 

48 


ACCUMULATOR 

TIMER 

PSW 

PCL 

PCH 

PORT 0 (BUS) 
PORT 1 
PORT 2 
MISC 


0 

AC 

FO 

RB 

FI 

S2 

Si 

So 


READ-ONLY 

READ-ONLY 


Counter 

Timer 

Timer 

Nested 

Will 

Mem 

T1 

TO 

Run 

Run 

Flag 

Fr Int 

En Int 

Bank 




PROMPT 48 provides 256 bytes of data memory numbered O-FFig. 

__{SMA}^ 

[NO BREAK] — ■ ' ^ 

—([WITH BREAK]-, 

'[SINGLE STEP]V 


[GO]- 


- y{SMA}^ 


v[J 




Ensure you have selected the correct access code, P2 MAP and LSN P2 contents before 
running programs. 


{SMA} Starting register/memory address 
{DATA} Data 


Functions 

ACCESS [A] {0-5} [.] 


Access 

Code 

Program 

Memory 

System I/O and 
System Calls 

Expansion 
Memory and I/O 

OUTL 

Port 0 

0 

WRITABLE (RAM) 

no 

no 

yes 

1 

WRITABLE (RAM) 

no 

yes 

no 

2 

WRITABLE (RAM) 

yes 

no 

no 

3 

READ ONLY (ON CHIP) 

no 

no 

yes 

4 

READ ONLY (ON CHIP) 

no 

yes 

no 

5 

READ ONLY (ON CHIP) 

yes 

no 

no 
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Command/Function SuminaFy 


Prompt 48 


BREAKPOINT 


[B]r~ 


{0-7}- 


□ 

[.] 


JL 


[.] 

{BKA} yj/ [,] 




[PREVIOUS] 


clears breakpoint number 0-7 
clears all breakpoints 



CLEAR 


.[REGISTER] » 

[C] ([PROG MEM]y 

[DATA MEM]' 


{SMA} [,] {EMA} [.] 


DUMP 


[REGISTER] 

[D] ([PROG MEM]-V 

[DATA MEM]' 


{SMA} [,] {EMA} [.] 


ENTER 


[REGISTER] 

[E] ([PROG MEM]-V 

[DATA MEM]' 


{BIAS} [.] 


EPROM PROGRAM 
FOR DEBUG (8748) 

EPROM PROGRAM NO 
DEBUG (8748,41,55) 

EPROM COMPARE 

FETCH EPROM 

HEX CALCULATOR 

MAP P2 


[7] {SMA} [,] {EMA} [,] {SEP} [.] 
[3] {SMA} [,] {EMA} [,] {SEP} [.] 

[8] {SMA} [,] {EMA} [,] {SEP} [.] 
[F] {SMA} [,] {EMA} [,] {SEP} [.] 
[6] {DATA} [,] {DATA} [.] 

[2] {DIR} [.] 


Each bit of DIR is direction, l = input, 0=output. 


MOVE MEMORY 


[REGISTER] 
[8]-([PROG MEM]V 
[DATA MEM]' 


{SMA} [,] {EMA} [,] {DMA} 


[.] 


SEARCH BYTE 

[REGISTER] \ 


[4]- 


PROG MEMlV {SMA} [,] {EMA} [,] {MASK} [,] — {DATA} — (f lWf’]) 7 

;data mem]/ / 


SEARCH 2 BYTES 


[5]- 


JREGISTER] V ji ,n 

TDATA ME^/ [,]— {HMASK} [,] {LMASK} {HDATA} [,] {LDATA}_{[-j)^;j)^ 
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Prompt 48 


Command/Function Summary 


{BIAS} 

Bias offset to load address 

{BKA} 

Breakpoint address 

{DATA} 

Data 

{DIR} 

Direction for lines of Port 2 

{DMA} 

Destination memory address 

{EMA} 

Ending memory address 

{HDATA} 

High byte of data 

{HMASK} 

High byte of mask 

{LDATA} 

Low byte of data 

{LMASK} 

Low byte of mask 

{MASK} 

Mask 

{SEP} 

Starting EPROM address 

{SMA} 

Starting memory address 


E-3/E-4 




Z-d/.I-d 
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MICROMAP 







APPENDIX G 
INSTRUCTION SET SUMMARY 


BY MNEMONIC 


ADD A. RO 

68 


R1 

69 


R2 

6A 


R3 

6B 


R4 

6C 


R5 

6D 


R6 

6E 


R7 

6F 


ADD A, @R0 

60 


@R1 

61 


ADD A. #data 

03 

m 

ADDC A. RO 

78 


R1 

79 


R2 

7A 


R3 

7B 


R4 

7C 


R5 

7D 


R6 

7E 


R7 

7F 


ADDC A. @R0 

70 


@R1 

71 


ADDC A. #data 

13 

m 

ANL A, RO 

58 


R1 

59 


R2 

5A 


R3 

5B 


R4 

5C 


R5 

5D 


R6 

5E 


R7 

5F 


ANL A. @R0 

50 


ANL A, @R1 

51 


ANL A, #data 

53 

□□ 

ANL BUS. #data 

98 

□□ 

PI, #data 

99 

m 

P2, #data 

9A 

m 

CALL Oaddr 

14 

m 

laddr 

34 

m 

2addr 

54 

m 

3addr 

74 

m 

4addr 

94 

m 

5addr 

B4 

m 

Gaddr 

D4 

m 

7addr 

F4 

m 

CLR A 

27 


CLR C 

97 


CLR FO 

85 


CLR F1 

A5 


CPL A 

37 


CPLC 

A7 


CPL FO 

95 


CPL FI 

B5 


DA A 

57 


DEC A 

07 


DEC RO 

C8 


R1 

C9 


R2 

CA 


R3 

CB 


R4 

CC 



DEC R5 

CD 


R6 

CE 


R7 

CF 


DIS 1 

15 


DIS TCNTI 

35 


DJNZ R0,addr 

E8 

m 

R 1 ,addr 

E9 

m 

R2,addr 

EA 

m 

R3,addr 

EB 

m 

R4,addr 

EC 

m 

R5,addr 

ED 

m 

R6,addr 

EE 

m 

R7.addr 

EF 

m 

EN 1 

05 


EN TCNTI 

25 


ENTO CLK 

75 


INS A. BUS 

08 


IN A. PI 

09 


IN A, P2 

OA 


INC A 

17 


INC RO 

18 


INCRl 

19 


INC R2 

1A 


INC R3 

IB 


INC R4 

1C 


INC R5 

ID 


INC R6 

IE 


INC R7 

IF 


INC @R0 

10 


INC @R1 

11 


JBO addr 

12 

m 

JB1 addr 

32 

m 

JB2 addr 

52 

m 

JB3 addr 

72 

m 

JB4 addr 

94 

m 

JB5 addr 

B2 

m 

JB6 addr 

D2 

m 

JB7 addr 

F2 

m 

JC addr 

F6 

m 

JFO addr 

B6 

m 

JF1 addr 


m 

JMP Oaddr 

04 

m 

laddr 

24 

m 

2addr 

44 

m 

3addr 

64 

m 

4addr 

84 

m 

5addr 

A4 

m 

6addr 

C4 

m 

7addr 

E4 

m 

JMPP @A 

B3 

m 

JNC addr 

E6 

m 

JNI addr 

86 

m 

JNTO addr 

26 

m 


JNT1 addr 

46 

m 

JNZ addr 

96 

m 

JTF addr 

16 

m 

JTO addr 

36 

m 

JT1 addr 

56 

m 

JZ addr 

C6 

m 

MOV A, #data 

23 

m 

MOV A, PSW 

C7 


MOV A. RO 

F8 


R1 

F9 


R2 

FA 


R3 

FB 


R4 

FC 


R5 

FD 


R6 

FE 


R7 

FF 


MOV A, @R0 

FO 


@R1 

FI 


MOV A. T 

42 


• MOV PSW. A 

D7 


MOV RO, A 

A8 


R1. A 

A9 


R2. A 

AA 


R3. A 

AB 


R4, A 

AC 


R5, A 

AD 


R6, A 

AE 


R7, A 

AF 


MOV RO, #data 

B8 

m 

R1 , #data 

B9 

m 

R2, #data 

BA 

m 

R3, #data 

BB 

m 

R4, #data 

BC 

m 

R5, #data 

BD 

cn 

R6, #data 

BE 

m 

R7, #data 

BF 

m 

MOV @R0, A 

AO 


MOV @R 1 , A 

A1 


MOV @R0, #data 

BO 

m 

@R1, #data 


m 

MOV T, A 

62 


MOVD A. P4 

OC 


P5 

OD 


P6 

OE 


P7 

OE 


MOVD P4, A 

3C 


P5, A 

3D 


P6, A 

3E 


P7, A 

3F 


MOVP A,@A 

A3 


MOVP3 A. @A 

E3 


MOVX A, @R0 

80 


@R1 

81 


MOVX @R0. A 

90 


@R1, A 

91 


NOP 

00 



ORL A, RO 

48 

R1 

49 

R2 

4A 

R3 

4B 

R4 

4C 

R5 

4D 

R6 

4E 

R7 

4F 

ORL BUS, #data 

88 m 

P1, #data 

89 CD 

P2, #data 

8A m 

ORLD P4. A 

8C 

P5, A 

8D 

P6, A 

8E 

ORLD P7, A 

8F 

OUTL BUS, A 

02 

PI, A 

39 

P2, A 

3A 

RET 

83 

RETR 

93 

RL A 

E7 

RLC A 

F7 

RR A 

77 

RRC A 

67 

SEL MBO 

E5 

SEL MB1 

F5 

SEL RBO 

C5 

SEL RBI 

D5 

STOP TCNT 

65 

STRT CNT 

45 

STRT T 

55 

SWAP A 

47 

XCH A, RO 

28 

R1 

29 

R2 

2A 

R3 

2B 

R4 

2C 

R5 

2D 

R6 

2E 

R7 

2F 

XCH A, @R0 

20 

XCH A. @R1 

21 

XCHD A. @R0 

30 

@R1 

31 

XRL A. RO 

D8 

R1 

D9 

R2 

DA 

R3 

DB 

R4 

DC 

R5 

DD 

R6 

DE 

R7 

DF 

XRL A, @R0 

DO 

@R1 

D1 


• CARRY FLAG AFFECTED 


All mnemonics copyright © 1976, 1977, 1978 Intel Corporation 






APPENDIX H 
HEXADECIMAL/BINARY 
CONVERSION TABLE 


HEX 

0 

1 

2 

3 

4 

5 

6 

7 

8 
9 
A 
B 
C 
D 
E 
F 


BINARY 

0000 

0001 

0010 

0011 

0100 

0101 

0110 

0111 

1000 

1001 

1010 

1011 

1100 

1101 

1110 

1111 
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Hexadecimal/Binary Conversion Table 



0 

0 

0 

0 

0 

0 

0 

0 

0 

0 

Ql 

■1 


1.048.576 

1 

65,536 

1 

4.096 

1 

256 

1 

16 


HI 

2 

2.097.152 

2 

131,072 

2 

8.192 

2 

512 

2 

32 



3 

3.145.728 

3 

196.608 

3 

12.288 

3 

768 

3 

48 


mm 

4 

4,194.304 

4 

262.144 

4 

16.384 

4 

1,024 

4 

64 


4 

5 

5.242,880 

5 

327.680 

5 

20.480 

5 

1.280 

5 

80 


5 

6 

6,291.456 

6 

393,216 

6 

24,576 

6 

1,536 

6 

96 



7 

7.340,032 

7 

458,752 

7 

28.672 

7 

1,792 

7 

112 


HI 

8 

8.388,608 

8 

524,288 

8 

32.768 

8 

2,048 

8 

128 

8 

8 

9 

9.437.184 

9 

589,824 

9 

36,864 

9 

2.304 

9 


9 

9 

A 

10.485,760 

A 

655,360 

A 

40.960 

A 

2.560 

A 


A 

10 

B 

11,534.336 

B 

720.896 

B 

45,056 

B 

2.816 

B 


B 

11 

C 

12,582,912 

C 

786.432 

C 

49.152 

C 

3.072 

C 


C 

12 

D 

13.631.488 

O 

851,968 

D 

53.248 

0 

3.328 

■1 


O 

13 

E 

14.680,064 

E 

917,504 

E 

57,344 

E 

3.584 



E 

14 

F 

15.728,640 

F 

983.040 

F 

61,440 

F 

3,840 

■i 


F 

15 


0123 


BYTE 


0 1 23 I i 
BYTE 


Prompt 48 























































APPENDIX I 

ACCESS CODE/LSN P2 MAP SUMMARY 


Access 

Code 

Program Memory 

System 

I/O & 
Calls 

Expansion 
Memory 
& I/O 

OUTL 
Port 0 

Allowed 

LSN P2 Map 

0 

RAM 

No 

No 

Yes 

output (0) only 

1 

RAM 

No 

Yes 

No 

input or output 

2 

RAM 

Yes 

No 

No 

output only 

3 

On-chip 

ROM/EPROM 

No 

No 

Yes 

input or output 

4 

On-chip 

ROM/EPROM 

No 

Yes 

No 

input or output 

5 

On-chip 

ROM/EPROM 

Yes 

No 

No 

output only 


1 - 1 / 1-2 






APPENDIX J 
EXPANDED ACCESS CODES WITH 

6 MHZ OPTION 


For those systems equipped with the 6 MHz upgrade option, the following twelve access 
codes are operative: 




OUTL 

Expansion 

Expansion 

System I/O 


Access = 

Port 0 

Memory 

I/O 

& Calls 


( 

0 

Yes 

No 

No 

No 



1 

No 

Yes 

No 

No 

Prompt RAM 


2 

Yes 

No 

No 

Yes 

for Program Memory 


3 

Yes 

No 

Yes 

No 



4 

No 

Yes 

Yes 

No 



5 

Yes 

No 

Yes 

Yes 



10 

Yes 

No 

No 

No 

On-chip 
ROM/EPROM 
for Program Memory 

1 

11 

12 

13 

14 

No 

Yes 

Yes 

No 

Yes 

No 

No 

Yes 

No 

No 

Yes 

Yes 

No 

Yes 

No 

No 


y 

15 

Yes 

No 

Yes 

Yes 


The equivalents of the original 6 access codes are: 


Old Access 

New Access 

0 

0 

1 

4 

2 

2 (with OUTL, too) 

3 

10 

4 

14 

5 

12 (with OUTL, too) 






INDEX 


Access Code Considerations, P2 Map, LSN 
of P2, 6-11 

Access Code/LSN P2 Map 
Sunimary, 5-7, 1-l 

Access Code/P2 Map Summary, 5-6 
Access Codes, A-5 
Access Mode Code Summary, 5-6 
Access Mode Control, 5-5 
Access Mode Select Command, 5-6 
Accumulator, 3-2 
Accumulator Instructions, 3-15 
Addition, Binary, 2-3 
Arithmetic, Binary, 2-2 
Assembling IMP and CALL 
Instructions, 6-7 
Assembly, Hand, 6-5 

Baud-Rate Selection, 6-14 
Binary Addition, 2-3 
Binary Arithmetic, 2-2 
Binary Digits, Electrical 
Representation of, 2-8 
Binary Division, 2-5 
Binary Multiplication, 2-5 
Binary Numbers,^ 2- 1 
Binary Subtraction, 2-3 
Bits, Bytes, and 

Where You Can Put Them, 3-2 
BLK System Call, B-3 
Breakpoints, 5-1 1 
Breakpoints, Running With, A-9 
Breakpoints, Setting, A-8 
Byte Search Data Memory Command, 5-13 
Byte Search Memory, A-1 1 
Byte Search Program Memory 
Command, 5-13 
Byte Search Register Memory 
Command, 5-14 

Bus Connector and I/O Ports Pin List, 4-5 
Bus Expansion, 4-5 

Clear Register Memory Command, 5-17 
Clear Data Memory Command, 5-17 
CALL Instruction Assembly, 6-7 
Care and Feeding of EPROMs, 6-7 
Clear Memory Commands, 5-17, A- 10 
Clear Program Memory Command, 5-17 
Code Generation, 6-2 
Command Description Formats, 5-4 
Command Function Group, 5-1 
Command Input Options, 5-5 
Command Keys, 5-2 
Command List Summary, 5-22, E-1 
Command Prompts, 5-5 
Command/Function Summary, E-1 
Command, Byte Search Data 
Memory, 5-13 

Command, Byte Search Program 
Memory, 5-13 


Command, Byte Search Register 
Memory, 5-14 

Command, Clear Data Memory, 5-17 
Command, Clear Program Memory, 5-17 
Command, Clear Register Memory, 5-17 
Command, Compare EPROM, 5-21 
Command, Dump Data Memory, 5-18 
Command, Dump Program Memory, 5-18 
Command, Dump Register Memory, 5-18 
Command, Enter Into Data Memory, 5-19 
Command, Enter Into Program 
Memory, 5-19 

Command, Enter Into Register 
Memory, 5-19 

Command, EPROM Programming, 5-19 
Command, Examine Modify, 5-9 
Command, Examine/Modify 
Breakpoint, 5-11 
Command, Fetch EPROM, 5-21 
Command, Go/No Break, 5-1 1 
Command, GO/ With Break, 5-11 
Command, Hexadecimal Arithmetic, 5-19 
Command, Move Data Memory, 5-16 
Command, Move Program Memory, 5-16 
Command, Move Register Memory, 5-16 
Command, Program EPROM With 
Reentry Code, 5-20 

Command, Program EPROM Without 
Reentry Code, 5-20 
Command, Search Memory, 5-12 
Command, Word Search Program 
Memory, 5-14 

Command, Word Search Register 
Memory, 5-15 

Compare EPROM Command, 5-21, A- 12 
Configuration, Hardware, 6-2 
Connector J2 Pin Connections, 6-13 
Control, Access Mode, 5-5 
Control Instructions, 3-20 
Conversion Table, Hexadecimal/ 

Binary, H-1 

Converting Decimal Numbers To Binary 
Numbers, 2-2 
Counter, Program, 3-3 
Counter, Timer/Event, 3-7 


Data Input, Strobed, 6-18 
Data Memory, 4-4 
Data Memory Considerations, 6-10 
Data Memory, Examining and 
Modifying, A-5 
Data Memory, External, 3-12 
Data Paths, 3-13 

Data Paths Using INS A, Bus, 6-19 
Debugging and Program Test, 6-6 
Description, Hardware, 4-1 
Description, Monitor Firmware, 4-4 
Description, Panel, 5-1 


Index- 1 



Prompt 48 


Design for “Von Neumann” Expansion 
Memory, 6-9 
Design, Program, 6-3 
DGOUT System Call, B-4 
DGSTG System Call, B-4 
Display, Command Function Group, 5-1 
Division, Binary, 2-5 
Dump Data Memory Command, 5-18 
Dump From Memory, A- 10 
Dump Memory Commands, 5-17 
Dump Program Memory Command, 5-18 
Dump Register Memory Command, 5-18 

Electrical Representation of Binary 
Digits, 2-8 

ENREF System Call, B-3 
Enter Into Data Memory Command, 5-19 
Enter Into Memory Command, 5-18, A- 10 
Enter Into Program Memory 
Command, 5-19 
Enter Into Register Memory 
Command, 5-19 

EPROMs, Care and Feeding, 6-7 
EPROM Programming Command, 5-19 
EPROM Programming, Fetch, Compare 
Commands, 5-19 
Examine/Modify Breakpoint 
Command, 5-11 

Examine/Modify Register Command, 5-9 
Examine/Modify Program Memory 
Command, 5-9 

Examine/Modify Commands, 5-9 
Examining and Modifying Data 
Memory, A-5 

Examining and Modifying Program 
Memory, A-4 

Examining and Modifying Registers, A-2 
Execution Programs, A-7 
Execution Socket, 5-3, A-1 
Expanded Access Code With 6 MHz 
Option, J-1 

Expanding PROMPT 48 I/O Ports, 6-10 
Expansion, Bus, 4-5 

External Connections, Teletypewriter, 6-15 
External Data Memory, 3-12 
External Memory and Ports, 3-11 
External Ports, 3-13 
External Program Memory, 3-11 

Fetch EPROM Command, 5-21, A- 12 
Flags, 3-4 

Firmware Description, Monitor, 4-4 
Format, Hexadecimal Object File, D-1 
Formats, Command Description, 5-4 
Function Key, Hex Data, 5-2 
Function Summary, E-1 
Functional Block Diagram, 4-2 
Functional Definition, 6-1 

Generation, Code, 6-2 
Getting Started, 1-2 
GO Command and Breakpoints, 5-11 
Go/No Break Command, 5-11 
GO/ With Break Command, 5-12 


Hand Assembly, 6-5 

Handling the Processor, 1-1 

Hardware Configuration, 6-2 

Hardware Considerations, 6-8 

Hardware Descriptions, 4-1 

Harrard Architecture, 3-1 

Historical Perspective, 3-1 

Hex Calculator, A- 12 

Hex Data/Function Keys, 5-2 

Hexadecimal/Binary Conversion, 5-8, H-1 

Hexadecimal Arithmetic Command, 5-19 

Hexadecimal Numbers, 2-6 

Hexadecimal Object File Format, D-1 

Hot Lines, Service, A-1 

How To Use This Book, 1-1 

HXOUT System Call, B-4 

I/O Port, Serial, 6-13 
I/O Ports, Using and Expanding, 6-10 
I/O Ports and Bus Connector (Jl), 5-3 
I/O Ports and Bus Connector 
Pin List, 4-5,6-10 
Input/Output, 4-4 
Input/Output Instructions, 3-15 
Input/Output Ports, 3-10 
INS A, Bus, Use of, 6-18 
INS A, Bus Data Paths, 6-19 
Inserting Processor In Execution 
Socket, 1-1 

Instruction Set Summary, G- 1 
Instruction Set, MCS 48, 3-15 
Instructions, Accumulator, 3-15 
Instructions, Control, 3-20 
Instructions, Input/Output, 3-15 
Instructions, Register Accumulator, 3-15 
Intel Service Hot Lines, A-1 
Interfacing To A Teletypewriter, 6-14 
Internal Modifications, 

Teletypewriter, 6-14 
Interrupt/Reset Group Keys, 5-2 
Interrupts, A- 13 

Inverse State (Negative True), 2-9 

J2 Pin Connections, 6-13 
JMP Instruction Assembly, 6-7 

KBIN System Call, B-2 
KBST System Call, B-2 
KDBIN System Call, B-1 

Logic, Negative True, 2-9 

Logic, Positive True, 2-8 

LSN P2 Map Summary, Access Code, 5-7 

Map Command, Port 2, 5-8 
Map, P2, A-6 
Mapping, Port 2, 5-7 
MCS 48 Architecture, 3-2 
MCS 48 Instruction Set, 3-15 
Memory, 4-3 

Memory Move Command, 5-15 
Memory Paging, Program 6-7 
Memory, Byte Search, A-1 1 
Memory, Data, 4-4 
Memory, Dump, A- 10 


Index-2 



Memory, Enter Into, A- 10 
Memory, External Data, 3-12 
Memory, External Program, 3-11 
Memory, Program, 3-3, 4-3 
Memory, Register, 3-2 
Memory, Word Search, A-1 1 
Micromap, F-1 

Modes 0, 2, or 5, Map ESN as Output, 6-11 
Mode 1 or 4 Mapping is Don’t Care, 6-12 
Mode 3 Mapping May Be Input or 
Output, 6-12 

Mode Control, Access, 5-5 
Modifying Data Memory, A-5 
Modifying Program Memory, A-4 
Modifying Registers, A-2 
Monitor Firmware Description, 4-4 
Move Program Memory Command, 5-16 
Move Data Memory Command, 5-16 
Move Memory Commands, 5-15, A- 12 
Move Register Memory Command, 5-16 
Multiplication, Binary, 2-5 

Negative True Logic, 2-9 
Number Systems, 2-1 
Numbers, Binary, 2-1 
Numbers, Hexadecimal, 2-6 

Options, Command Input, 5-5 

P2 LSN Considerations, 6-13 
P2 Map, A-6 

P2 Map Summary, Access Code, 5-6 
P2 Map, LSN of P2, Access Code 
Considerations, 6-11 
Paging, Program Memory, 6-7 
Panel Description, 5-1 
Panel Layout, PROMPT 48, 5-1 
Paths, Data, 3-13 
Pin List for I/O Ports and Bus 
Connector, 4-5, 6-10 
Pointers, RAM, 3-2 
Pop, Stack, 3-9 

Port 2 and Port 2 Mapping, 5-7 
Port 2 Bus Structure, 6-12 
Port 2 Map Command, 5-8 
Port 2 Map Command Data Bits Vs 
Port 2 Pin Numbers, 5-8 
Port 2 Mapping, 6-11 
Port Strapping Options, Serial I/O, 6-14 
Ports, Input/Output, 3-10 
Ports, External, 3-13 
Positive True Logic, 2-8 
Princeton Architecture, 3- 1 
Princeton Heard From, 3-1 
Processor, Handling, 1-1, A-1 
Program Counter, 3-3 
Program Design, 6-3 
Program EPROM, A- 13 
Program EPROM For Debug, A- 13 
Program EPROM With Reentry 
Code Command, 5-20 
Program EPROM Without Reentry 
Code Command, 5-20 
Program Execution, A-1 
Program Memory, 3-3, 4-3 


Program Memory, External, 3-11 
Program Memory Examine/Modify 
Command, 5-9, A-4 
Program Memory Paging, 6-7 
Program Test and Debugging, 6-6 
Programming Example, Stopwatch, C-1 
Programming Socket, 5-3 
Programming Techniques, 6-3 
PROMPT 48 Considerations, 6-8 
PROMPT 48 Panel Layout, 5-1 
Prompt 48 Purpose, 1-2 
Prompts, Command, 5-5 
Purpose of Prompt 48, 1-2 
Push, Stack, 3-8 

Questions Most Often Asked, 6-18 

RAM and I/O Selection, 6-19 

RAM Pointers, 3-2 

REFS System Call, B-2 

Register Accumulator Instructions, 3-15 

Register Memory, 3-2 

Register Memory Summary, 

Special Purpose, 5-10 
Register, Examine/Modify Command, 5-9 
Registers, Examining and Modifying, A-2 
Registers, Working, 3-2 
Reset the System, A-1 
Reset/Interrupt Group Keys, 5-2 
Restrictions, Hardware, 4-6 
Running With Breakpoints, A-9 

Search Memory Command, 5-12 
Select Command, Access Mode, 5-6 
Serial I/O Port, 6-13 
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